{чч екан» 
ЖЕ НЗ SE 








ЛЕ 


(ва) 


EFH gu 








G ЛЕНИЕ 


1.200 
1.2.1 ППП 
1.2.2 [LI II 
1.2.3 ППИ 
1240000 

020 00 

2.1 ППВеа!5 
2.1.1 ПРОЅІХОЦЦЦІ 
2.1.2 [105 ХПППИ 
2.1.3 [|Windows[]]] 

2.2 ПППОПвеа 5 
2.2.1 []|]Redis 
2.2.2 []|]Redis 

2.3 Вед! ДП) 
2.3.1 ПП 
2.3.2 ІП 

2.4 П] 

2.5 ПЦ 





Пай 0 
4.1 [|| 
41101 


4.1.2 0000 
4.1.3 МАТСНОООО 





050 00 
5.1 PHP[]Redis 
5.1.1 ПП 
5.1:2 HH 
5.1 ЛИ 
5.1.4 00000000000 
5.2 Ruby[]Redis 








5.3 Python[]Redis 
2.1 1n 
5.3.2 ІП 
5.3.3 ОППП 
5.3.4 11111 
5.4 Node js[]Redis 
5.4.10 
5.4.2 ІП 
5.4.3 ШШШ 
5.4.4 ПОШРИПОП 
060 00 
6100 
6.1.1 ПЛОД 
6.1.2 00000000N 
6.2 Шиа] 
6.2.1 Виа] 





7.1.2 TILL SAVED] ВОБАМЕ | 
7.1.3 ПП ЕЦЈБНА | 








9.3.1 redis-cli 
9.3.2 phpRedisAdmin 


9.3.3 Rdbtools 
ША Redis[ ПП 
A.1 REDIS CMD WRITE 
A.2 REDIS CMD DENYOOM 
A.3 REDIS CMD NOSCRIPT 
A.4 REDIS CMD RANDOM 
A.5 REDIS CMD SORT FOR SCRIPT 
A.6 REDIS CMD LOADING 
ПОВ 10010 
ШС СВС16 III 


Кеаіѕ000000200 
ШП 00 


ППТ 
00 


ОООООООСТРООО 

RedisQUO00/O00000--200--OQ00000000002015.5 

ISBN 978-7-115-38840-7 

ПФК... ІПФП.. ШПФПЦПП-ППІП ІМОФТР311.13 

ООПОБОБСРОООЮО20150П0 7 212 21] 

0000 

ОО0000Кеаіѕ$Пр00000000000000000Аеаіѕ 0000000000000 
ОДОб00000000000000веаїз ддрдд0000000веаї  О ОбД00000000 
О0000000Аеаіѕ$О0000000000000000000РНРОКирурРуёћопр 
Node. js4Q000RedisQO00000000 

ОО000000000Аеаіѕ$=П000000000000Аеаіѕ 0000000000000 
00000000000000000000000000000000000Ве91$00000000000 
ОООД0000000000000000 

el LU 

0000 000 

0000 000 000 

•10000000000 0000000000110 

00 100164 0000 315@ptpress.com.cn 

ПП http://www.ptpress.com.cn 

ОДО0000000000 

e[j]]800x1000 1/16 

00014 

00029600 2015050020 

0006501-9500П 20150500001000 

00049.000 
0000000(010)81055410 (000000(010)81055316 
000000(010)81055315 


Ш 


Кеа 6 ПДОДОДУ евро ДОООДОООДОО000000000000000040000 
Web 2.О00000000000000000000000000000000000000000000 
ороборррборбрбобобоборборрорбоборборордорордоровеаїь 000 
00020000000000000 

Redis QUQ0U0000000000000000000000 000000000000 
Кеа 6 ОПОПОПОПОПОПКей 5 000Кеаї  ПООООООООО00000000000 
обобобоббббобово 

ООООК ей  ОПОПОПООООООБОВОБОПОООПКейт 000 

02000 

ООООЗОПОООПОБОПЕчаййОкКеатв 2.6000000000Аеаіѕ ПП 
О050000000000000000000000Аеаіѕр000000000003.0000000 
HORedis ОООООООООД00О000000000000000000000000000Веаїз 
Salvatore Ѕапћірро0000000000*000Аеаіѕ 0000000 
ведїв'ПОДО0"00000 Redis’ ОПОПОООПООООБОБОВО” 0000000000 
О000000000006еаіѕ$ПОО000000000Аеаіѕ=00000020000000000 
ОАеаіѕ000000000000000000000000000010000000 

0000 

ОПОПОООКеа 6 ПОПОПОПООКей в ЮДОДОПОДОООДО0000Веаїз 
ОООООООООООКей в ОООПОООПООООООБОБОПООКеЯт 0000 

ОООПООООКеа 5 ОПООПОПОООПОООКее в pam bab m pa DUC 
обобобобобобобобббоббббббобобобобоборбо 


ОббоббобооОкеетаоооороороороууевоооороонпихоро 
ПО000000000000000 

0000 

О10000Аеаіѕро0000000000000000000000Аеаіѕ$ 00000000 
UURedis[] 

0200000000000Веа!00000000000000Веа1500000000000 
0000000000000000000000000000000000000000000Веа1$008 
ОООООДО0000000000000000000000 

030000Ве91$00000000000000000000000000000000000 
0000000000000000000030000000000000000 Redis В000000 
HL IRedis[| 

04000000Ве91$1000000000000000000000000000000000 
ШШШШШШШП 

05 0000000000000000 Кей  ПООООООРНРОК“ БубрРутпопО 
Моде.)5 ОПО0ДОДО0000р000000000000000000000000000000 
ООО0000000 

060000Аеаіѕро00000000000000000000000Аеаіѕ$р000000 
ОООООДО00000000000000000000 

07 0000Аеаіѕро000000АеаіѕП0000АОВЦАОҒОО0000000000 
ПАеаіѕ$0000000000000000 

0800000000Веа1$00000000000000000000000000000000 
ОООООДО0000000000 

П90000Аеаіѕро000000000000000000000Аеаіѕ$00000 

ПОАО00АеаіѕО00000000000000 

ПОВО00Аеаі:ѕ 00000000000 

ПОСОООАеаѕ0САС1600000 

0000 


ОО0000000000000 

e П000000000000000000000000000Аеаіѕ 0100000000000 
00008 

e ПО бОбобооорроророророодродоодоодоосоооооб 

e 0000000000000000000000О0О0ОО«еа ПОП 

e UU DOO I TED C 

$ redis-cli PING 

PONG 

e Ке9!500000000000000000000 

redis> SET foo bar 

OK 

e UU DD T 

var redis = require("redis"); 

var client = redis.createClient(); 

ИОПООО JSON 0000000000 

client.mset( 

‘user:1', JSON.stringify(bob), 
‘user:2', JSON. stringify (jeff) 

); 
0008 
ОбббоббббоБОбОБОБООВОБООКчБубРАРОООО 
def hsetnx($key, $field, $value) 

$isExists = HEXISTS $key, $field 
if $isExists is 0 
HSET $key, $field, $value 
return 1 
else 


return 0 

000000%00000Аеаіѕ$П00000000000000000000000000риіпё 
000000%00000000000000000 

0000 

00050000000000000000000000000000000000000000000 
ОООООДО0000000000000000000 

DEEBOUDUCIOCIDGIitHub[][]https ://github.com/luin/redis-book- 
assets|[|[ |] JGitHub| 000000 

ПП 

ОООООДО000000000000000000000000000000000000000 

ОООООДО0000000000000000000000000000000000 

ОООООДО000000000000000000000000000000000000000 

ОООООДО0000000000000000000000000000000000000000 
ОООООДО00000000000000000000000000 

ОДО0000"000"000000000000000000000000000000000000 
ОООООДО0000000000000000000000000000000000000000000 
0000000000000000000000000000Веа!0000000000000 

оебобобоббодадодобобободадодобоббобббобадодо 


ШЦ 


Кеаіѕ0ПООО00000000000000000000000000000000000000 
ОДОД0000000000 Redis ПОООО0000000000000000000000000 
Ор00000Веаїь Дб0000000000000кеаї 00000000 


1.1 00000 


200800000000000ОМегаа 1? ПрО0000МуЅО 00000000 


LLOOGG 121 ПППППППППППППП5а!маїоге Sanfilippo ППППМу5О1. 
ООО0000000000000-0000С60000000000002009000000000000 
ПКея  ПП5а!магоге Sanfilippo ППОПОПВеа!$ [I JLLOOGG 000 
ОООО000000000000000005аімаќїоге Sanfilippo[IRedis[ IILI 
ПКеа5ПППППППЦПППППР!еїег Noordhuis ПППППВеяаі 000000000 
Salvatore Ѕапћірроро00000000000000Аеаіѕ$0000000000 


ООНаскег Мем/ 20 120000000000000000 1! 00000001256000 
Прор«еа  ППОПООПООООПОООПОПС#НчД5васк Overflow[]Flickr[] 
Поб п5кадгат ОГ Кеа 50000 

ММмаге 1201 ОППОППКее 5 ППППза!матоге 5апйИррой 
Pieter Моогаһи5 ІППШІЗППЫПППУМмгаге( ППЕесі5П 


RedisQOO000GitHubqO000000_'*!.02015040200Redisqo0 
3.0.0000000 


1.2 [| 


000000000000Ве9!$000000000000000000 
1.2.1 (ТІП 


обабобоббдоббоббдобабобобобобабобббородо 
dict["key"] = "value"[] dict 0000000000000" key "O000 
О"матие" ОДОДОДООО0О00О0000000000000000000000 

Redis[]REmote Dictionary Ѕегмег0000000000000000000 
ООООООООООООТСРООООООООООООООООООООО00000Аеаіѕр0000 
ОО000000000000000000000000 Redis ПОбоборороро 

e (00 

e 00 

e 00 

еп 

e D 

000000000000000 МУЅОЦО000000000000000000000000 
ООООД00000000000ро5800000С00000000000000000000000 

post["title"] = "Hello World!" 

post["content"] = "Blablabla..." 

post["views"] = 0 

post["tags"] = ["PHP", "Ruby", "Node.js"] 

ОДОООД0000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 


0000.) ПООООООООЗООООООВОБОПОБО Redis 100000000000000 
ОООД0О00000000000000000000 Redis 00000 Redis ОДОД00000 


ОДОД00000000000 Redis ОДОДОООООО0О0О00000000000000000 
[0000000000000Ве9150000000000000000000000003.500000000 
00000000000“00000000А0008000000©00”000000000000000 
00000000 


1.2.2 [| IILI 


Redis [IILI III bn dad pam an Ве 5 000 
О00000000000000000000000000000000000Аеаіѕ=0000000000 
1000000 

О000000000000000000000000000000006еаіѕ000000000 
000000000000000000000000000000000 


1.2.3 ПППП 


Redis 100000000000000000000000000000000000000000 
Дрвеаї 00000000000 

Redis ОДПОДООО0000000Тіте То ПмеПтТТ ПІ 
Дрбр00000000веаїь III LIN IRedis[ IILI d ddr dr 
ООООО00000000000000Мепасаспеарр00000 

00 00 Redis П Memcached П0000000000000000000 Redis 
ОО000000Метсасћеароо000000000000000000000000000000 
обообобОКее тв tnn ad d ad and daa ad a dd d abad ada du 
0000000000000000Веа!$ 3.0 0000000Мепасаспеадррро000000 
RedisQQU0U00RedisQOU00000UMemcachedQO00000000000000 
Д000000000веаї)0Мепасаспеадрор000000 

0000000Кеаїз 1000000000000000000000000000000060000 
0000000000 


О0000Аеаіѕ ООООДОО0О00000000000000000000000000000 


О000000000000000Аеаіѕ ОД07 00/00" П000000000000000 12! 00 
00 


1.2.4 ПП 


О00000000000000000000000Аеаіѕ ДДОДОООДООООООВеаї5 
О0000000Кеаіѕ00000000000000000Аеаіѕро0о5о: 1000000000 
О00000000000роѕєѕПуіар1р00ерооо00000005010000 

SELECT title FROM posts WHERE іа = 1 LIMIT 1 

О00000Кеаіѕ$00000000оѕ:10000000ероооо0000000000 
000 

HGET post:1 title 

О0НСЕТрО00000Аеаіѕ$п0010000000001-100000000000000 
О0000000000000000000000030000006еаіѕ$=000050:0000000 


eoo Command reference - Redis “ 


Са (©) (e) [0] [se] (a) [Ж [M] (В) (48 чаво с Lesser] [O] 


- : 
redis Commands Clients Documentation Community Download Issues License 


(С Keys Strings Hashes Lists Sets Sorted Sets Pub/Sub Transactions Scripting Connection Server 
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КеаіѕД00000000000000000Кеаіѕ000000000000000 
http://download.redis.io/redis-stable.tar.gz[][][] 

О00000000000такеррооооооооо0000 

wget http://download.redis.io/redis-stable.tar.gz 

tar xzf redis-stable.tar.gz 


cd redis-stable 

make 

КеаіѕроО0000000000000000000Аеаіѕ$д000005ге000000000 
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OS X ПППООПОООНотевбгем []MacPorts ПЛДОДОДОЗОВеаЇ5 
LULLDLDDDUDDDUUDDUDURedisI ПООДООПРОЗІХОДОДООДОДОДООДОДОДО 
ПОНогамргем Ове 5000 

1000Нопебгеуу 

000000 ruby -e "$(curl -fsSkL 
гама Ећиб.сот/гтахсућотевбгем/до)"П000ОНотевбгем 

0000000 Нотебгем ПП brew update ППП Нотергеу/ ПП 
О00000Аеаіѕр 
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ПО brew install 0000000000000000 brew install геаіѕ$000 
Redis[] 

$ brew install redis 


==> Downloading 
https://downloads.sf.net/project/machomebrew/Bottles/re 
dis-3.0.0.yosemite.bottle.tar.gz 
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## 100.096 
==> Pouring redis-3.0.0.yosemite.bottle.tar.gz 
==> Caveats 
To have launchd start redis at login: 
In -sfv /usr/local/opt/redis/*.plist 
~/Library/LaunchAgents 
Then to load redis now: 
launchctl load 
~/Library/LaunchAgents/homebrew.mxcl.redis.plist 
Or, if you don't want/need launchctl, you can just run: 
redis-server /usr/local/etc/redis.conf 
==> Summary 
/usr/local/Cellar/redis/3.0.0: 10 files, 1.4M 
OS X OUUTiger 000000ачпсһа ДОДОДОДООДООДООПВеаїз ПП 
О00000000000000ачпсһћар 
In -sfv /usr/local/opt/redis/*.plist ~/Library/LaunchAgents 
launchctl load 
~/Library/LaunchAgents/homebrew.mxcl.redis.plist 
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setup.exe[] ]|Cygwin[]HTDUDUUCygwinrrnbaarnsetup. exert 
обедобабоврободоббоббобдобадобабобадовбоббабобоббббродо 
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Select Packages 
Select packages to install = 
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02-1 Cygwin 00000 

ОПООКео 5 ПОПОПППасеПтакейоопопой“О еуе! mtm 
“New” ППОПОО“ $ ктр"ОПОПОПОВОО“ Skip” Dana abd dd 
Суду пО000000000002-1000асс00000" Keep" Hub 
ОООО0000000000000000000000000000005екир.ехеррдр 00000 
000 

ОДО0000000000Оу декбдудддОВеаї  ДОбОО0000000000 
Мі паом ЗП ДОД0О00000Су думі ПДОООД0Д00000000міпадрОООВеаїя0 
ОПОБООООПСудмит 000000 

0000“ Мех” ПО000000000000000000 

ОДО00000ОСудмиїп Terminal В00000Суоміп ПППСуом/іп ПП 
Мі паом в ДОД000СудуміпоООООО0О000000000Судуміпродоробо 
ООМАпаом/$ ПОООС лсудмип П 
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ОО0б0Океа 00002. 1 140000000000О0Отакеррророрвеа 5000 
ОО0000ООСу а ммтарооооо 

О0005ге000геаіѕ. п00000000 

#ifdef CYGWIN 

#ifndef SA ONSTACK 

#define SA ONSTACK 0x08000000 

#endif 

#endif 

О0005ге000Оорјесё.сВ00000000 

#define strtold(a,b) ((long double)strtod((a),(b))) 

3000Redis 

02.1.1000000такероо000000 

ПП Cygwin О0000000ипих 00000Судмиїп (fork 00000000 
О0Аеаіѕ$П0000000СуоміпрО00Суоміпро0о0000Аеаіѕ00Кеаіѕ 
ОПОПОО пух Оз ХО00000000000пихр 
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000 Redis ВООООООООООО0000000000000000000Аеаіѕ= ПОПО 
О0000Аеаіѕ0000 
О000000000Аеаіѕ= 0000000000000 2-1 000000000000000 
О000000000000 make іп5са ПТОДОООО000000/ч5гЛосаї/іпрО000 
ОДООО00000000000000 
02-1 Кеа 0000000 
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redis-server Redis JR 4 at 

redis-cli Redis 11947 2 у 
redis-benchmark Redis tt few iA Г.Й. 
redis-check-aof AOF XER ТА 
redis-check-dump RDB (ЕТА. 

redis-sentinel Sentinel IRB CH 2.8 ЕЛЕ) 
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ПП Redis ОООДОДООООДО00000000000000000000000 
100000 
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$ redis-server 

[5101] 14 Dec 20:58:59.944 # Warning: по config file 
specified, using the default config. In order to specify a 
config file use redis-server /path/to/redis.conf 

[5101] 14 Dec 20:58:59.948 * Max number of open files 
set to 10032 


[5101] 14 Dec 20:58:59.949 # Server started, Redis 
version 2.6.9 

[5101] 14 Dec 20:58:59.949 * The server is now ready to 
accept connections on port 6379 


RedisQ000000063790(!2!_000--portQ0000000000 
$ redis-server --port 6380 


20000000000Веч!$ 
ОНичх0О0О0ОО0О0О0О0ОВе 1 0ОВеа1$ПППОПОПОВОВО0000 
ПОБОБОООВе 1 ППП 96 чииПРе ай ПОО0О0О000Ве91$010000 
ме50р0000000геаіз init всгір ДОООО00000000 
#!/bin/sh 
# 
# Simple Redis init.d script conceived to work on Linux 
systems 
# as it does use of the /proc filesystem. 
REDISPORT=6379 
EXEC=/usr/local/bin/redis-server 
CLIEXEC=/usr/local/bin/redis-cli 
PIDFILE=/var/run/redis_ ${REDISPORT }.pid 
CONF="/etc/redis/$ { REDISPORT }.conf" 
case "$1" in 
Start) 
if [ -f $PIDFILE | 
then 
echo "$PIDFILE exists, process is already running 
or crashed" 
else 
echo "Starting Redis server..." 
$EXEC $CONF 
fi 


stop) 
if [ ! -f $PIDFILE | 


then 
echo "$PIDFILE does not exist, process is not 
running" 
else 
PID=$(cat $PIDFILE) 
echo "Stopping ..." 
$CLIEXEC -p $REDISPORT shutdown 
while [ -x /proc/${PID} ] 
do 
echo "Waiting for Redis to shutdown ..." 
sleep 1 
done 
echo "Redis stopped" 
fi 
" 
echo "Please use start or stop as first argument" 


esac 
О00000Аеаіѕ=000000000000000000000000000000 
0100000000000000000000/еѓс/іпіє.а 00000000 redis. DID 
ПООПОООПОК ее ППОПОПОООПОБОПОООКее в рр000000600 
КЕРОІЅРОКТОО0000000000 
0200000000000002-20000000 
02-2 0000000000 


AR 4 l ВА 
/etc/redis {Е Redis AY ACE УС 
/так/тед15/т0 5 ЖҰ Redis FIFE ЖИЕ c ff 


030000000000000000000 2.4 П000000/еёс/геаіѕ ООДО0000 
0000" 6379.сопі")0000002-З0000000000000 
02-3 0000000000 





£ ay я іл BB 
daemonize yes fË Redis WAST {Pu AEH TIE 1T 
pidfile /var/run/redis #09 .раа МШ Redis PID ХУ E 
рогі iu BUEL Redis B Wr (sig FS 
dir /var/redis/3& 0 5 UEL FF AAE ХУТРІ EC 
ПО00000/еёс/іпіє.а/геаіѕ ПО005аО0Аеаіѕ 000000000000 
ПАеаіѕ$р0000000 


$ sudo update-rc.d redis ППП defaults 


2.2.2 ||| |Redis 


000 Redis 10000000000000000000000 Redis 1000000000 
ОПООООКей 5 000000 JRedisIIIISHUTDOWNII[I DDD 

$ redis-cli SHUTDOWN 

lRedis[|JSHUTDOWNIIIIIUILILDDUDDUDLLDUDUDDUULDUDDUII 
00000 

Вед! ІПІП 5ЗІСТЕВМОДОДОЛО kill Redis 000 РІБППІППІП 
Веда! ППШППППОНОТООУУМППППП 


2.3 Веадї5 [| 


ПО0000000000геаіѕ-сіі0000геаіѕ-с!ОАеаіѕ Command Line 
Interface[][]Redis[]T]HO DO nRedis pn iib m m pm i ndRedis min ind 
ОДОДОО00000веаї Про 000000 

000000000Огеаїв-сіївеаї ДДОДОДВеаї tm m m m n 
0000 


2.3.1 ПП 


Пргеа5- си Кеа III II redis-cIli rn 
0002.2.200000 redis-cli ЗНУТООУУМДгеаїв-сПІДДДДООО0000000 
000001 27.0.0.1000006379)00Кеаї000-00-РОООООО00000000 

$ redis-cli -h 127.0.0.1 -р 6379 

Кеа 5  ОДОРІМСООДДДОООДОВеаїЬВОДОДООООДОДОООООО 
PONGDDO 

$ redis-cli PING 

PONG 

ообообобододо геаіѕ-сірО000000000000000000000 

$ redis-cli 

redis 127.0.0.1:6379> PING 

PONG 

redis 127.0.0.1:6379> ECHO hi 

"hi" 

ООООДДД000000000000000000000000000000000000000 
redis>[]]] redis 127.0.0.1:6379>[] 


2.3.2 MONN 


000000000000000000000000000000 1.2.4 ОДОНСЕТОДОО 
О00000000000@ерооооо0о0000050000000000геаіѕ-сіро0000 
ОД00000000 

100000 

UUUUUstatus reply 00000000000000 Redis ПП SET 0000000 
О000АеаіѕО0000КОООО00000000000РІМСОО000РОМСПО000 
ООО00000000000000 

redis> PING 

PONG 

200000 

00000000000000000000 Redis Во000000еггог геріуд 0000 
О0(еггог)ОД0О0О000000000000000000000 

redis> ERRORCOMMEND 

(error) ERR unknown command 'ERRORCOMMEND' 

02. 600000000000" ЕКА"000002.800000000000000000000 
0000 

redis> LPUSH key 1 

(integer) 1 

redis> GET key 

(error) WRONGTYPE Operation against a key holding the 
wrong kind of value 

ОООО00000“МУАОМСТҮРЕ”ПО000000000000000000000000 
ОО000000000 

300000 

Redis ПООООООООДООО0О0О000000000Д00000000І/ІМСАООДОПО 
ОДООДО000000000000000000000000000000000000000 
ЮВ5124ЕП000000001пёедег геріу Д(іпседег) nnam 


redis> INCR foo 

(integer) 1 

4000000 

ОПОПООБъ!к гер!У000000000000000000000000060000000 
ООООДО0000000000000000000000000000 

redis> GET foo 

"1" 

000000000000000000000000000(71)000 

redis> СЕТ noexists 

(nil) 

ЗО00000000 

UOUUUUUUUmulti-bulk геріуроо000000000000000000000000 
ООООДО000000000000000000000000000000 

redis> KEYS Ж 

1) "bar" 

2) "Тоо" 

ПП КЕҮЅП000000000000000000000000006еаіѕ000000000 
О00000000000етр+у list ог зе 03.1 ОПОДПОДКЕУЗООООО0О0000 
ООО00000000000 


2.4 [| 


2.2.1 ПППППП redis-server ППППП port ПОП Redis О0000000 
0Ве9!500000000000000000000000000000000000000000000 
ОО000000000 Redis П000000000000000000000000000000000 
0000000000000геаїз-5егуег ПО 


$ redis-server /path/to/redis.conf 

LIBCIEBIDID IILI LILILILLILLILILILILILILILILILILI II HI 

$ redis-server /path/to/redis.conf --loglevel warning 

Кеаіѕ000000000000геаіѕ.соп 0000000000000 

О0000000Аеаіѕ 00000 CONFIG SET ВО000000Аеаіѕ 00000 
О0000Аеаіѕро000000 

геаіѕ> CONFIG SET loglevel warning 

OK 

0000000000000 CONFIG 5Е ТОПОПОПОВ ООООО0000000000 
О00000000000000 CONFIG СЕТ Во00Аеаіѕ 0000000000 

redis> CONFIG GET loglevel 

1) "loglevel" 

2) "warning" 


LLIIIILIIILI OU IILI I TD 


2.5 (ІП 


О10000Аеаіѕ$=00000000000000000000Аеаіѕ$р000000000000 
ООООДО000000000000000000000000000000000000000000000 
ОДООДО0000000000000000000000 

ООООО0000000000000000000Аеаіѕ$=0000160000000000000 
ааќабраѕеѕП00000000000Аеаіѕ000000000000000000000000 
ЗЕСЕСТОДОООО000000100000 

redis> SELECT 1 

OK 

redis [1]> GET foo 


(nil) 

ОООО00000000000000000000000000 Redis 10000000000 
ОДОД0000000000000000000000000000000000 Redis 0000000 
ОДООООД000000000000000000000000000000000000000000000 
ОООД0О0000000000000000Б005НАССОДОДОООДВеаЇ0СОДООООО 
ОДО000000000000000000000000000000000000000000000000 
ПО0000000000000000210000000000000000000000000000А000 
О000010000008000000000000000000Аеаіѕ=000000000Аеаіѕ00 
О0000006еаіѕ000000001мВвр0000000000Аеаіѕ=8000000000 
00 


0 Û 
[11. Microsoft Open Technologies Inc. ПППППППППІГТІЛІГІЛТІГІІ 
000 
[2]. https://github.com/MSOpenTech/Redis 
[3]. 6379 ПООПООПМЕВКДАДОООООМЕВКДАОООООО0ООООО 


ОЗО LIL 


О00000000Аеаіѕ00006еаіѕ0000000000000Кеаіѕ=0500000 
ОДОД0000000000000 Redis ОППООО000000000000 redis-cli 0000 
О0000000000000000000000000000000Аеаіѕ0000000000000 

ОООО00000000000000000000000000000000000000 Redis 
О000000000000000000000 Redis ПООО00000000000000000 
Кеаіѕ0П0000000006еаіѕП000000000000000000000000000000 
ПП Redis О00000----ОО000000000000000000000 

3.2003.6005000000Аеаіѕ=0500000000000004000000000*0 
070700707007070000707007 00000000000070070000700700000 
ОООО0000* 00" О0000000000000000000* 0000" О0000000000000 
00000000000 


3.1 П 


000 Redis ОООООООООООООООООООООООООО0О0О0000геаіѕ-сіір 
ОДО00000000000000 
1000000000000 
KEYS pattern 
рабкегпПОД9106000000000000003-1000 
03-1 glob 0000000 


? Пут 


LAUER САВО ГО FFF 

[] DU ACHE 5 AREER, uJ EH“ ES UR МУН, AN а[ь-а] RT LAPUA“ ab”, 
“ac” ЖІ “ad” 

\х Лес х, ЈЕТРЕ ХЕРЕ. ШО “7” su АЕ НА 2 





урвеаї  ПДОО00000000200000000000000000000000000000 
ПРооППОПОООКЕУЗПОПОПООПОКей 5  О00005ЕТО00003.2000000 
ППППрагППП 


redis> SET bar 1 
OK 
0000 KEYS *0000Аеаіѕ$П0000000000000000006а000 


KEYS ba*[|[] KEYS bar [III III 


00 


redis> KEYS Ж 
1) "Баг" 
ПП КЕУ5ОДДОО00ВеаїбООДОДОО00000000000000000000000 


ПП ВеаїбодрОДОДООДДОДООДОД0О0000000веаїз ПОП 
20000000000 

EXISTS key 
00000000000010000000000 
redis> EXISTS bar 

(integer) 1 

redis> EXISTS noexists 
(integer) 0 

30000 

DEL key [key ...] 
ООООДДО0000000000000000000 


redis> DEL bar 

(integer) 1 

redis> DEL bar 

(integer) 0 
О0000рЕШО000юаО000000000000000000000000 

ПП DEL ООООБОБОБОБОВБОБОБОБЕтлих 00 хагоѕ000000000 


ПО00000000000000*иѕег:”О000000000геаіѕ-сіі KEYS "user:*" | 
xargs redis-cli РЕШПООО DEL 000000000000000000 redis-cli 
DEL 'redis-cli KEYS "иѕег:*"` 000000000000000 


41000000008 


ТУРЕ key 
ТУРЕОООООООБООООООБОООООООвелтд rd dd ph ах РОДОДОООО 


listQO00000s etQ0000002s etO 00000000000 


00 


redis> SET foo 1 

OK 

redis> TYPE foo 

string 

redis> LPUSH bar 1 

(integer) 1 

redis> TYPE bar 

list 

ГРОИ5НППППППППШППППППШПППППШПППППППШППППППП 3.400000 


3.2 ІШІ 


ООДО00000000000000000000000"Ром/егеа by 


WordPress" A П0000000000000000000000000000000000000 
MySQLOQ00000000000000000000N ode Party] Redis ПП 
ОДОД0000000000000 Redis ОППОООО0000000000000000000000 
О000000000000000000000000000000006еаіѕП000000000000 
0000000000000 

000 

ППППППППППППППП Ве91$000000000000000000000000000000 
О0000000000Кеаіѕ00000 

0000000 

О00000000000 АКеаіѕ 00000 Кеаіѕ$ПО00000000000000000 
Кеаіѕ00000000000000 Аеаіѕ=000000000000000000Аеаіѕ= 0000 
ОДО000000 Аеаі$ПО0000000000000000000 Аеаіѕ= 00000000000 
ПООООООПООКей в ati aan aan pm p Regis n matin ut 
ПОПОВО 


3.2.1 ПП 


000000 Redis 000000000000000000000000000000000000 
О0000000150м 000000000000000000000000000000000512 
MB 121 п 

ДОДО00004000000000000000000000000000000000000000 
ОДОДОО000000000000000000000000000000000000000000000 
ОДОД000000000000 


3.2.2 [|| 
1000000 


SET key value 

GET key 

БЕТПСЕТПЕесіз 0000000000000000000000000000000О 
key = "hello"QRedisQO000000 

redis> SET key hello 

OK 

ОДО000000000 

redis> СЕТ key 

"hello" 

ообообоббобрдр 

ОООООООООО0000000000000000000000000000геаіѕ-сіі000 
ООО000000000000000500000000000000РНРрРуёпопАирур 
Моае.јѕ$0000Кеаі$0000 

ОДОДОД000000 Redis 10000000000000000000000000 PHP 
0000 ЅЕТ/СЕТОООООООООООООООООО0000 5ЕєТОДО0Веаї 0000 
000000000000000000000003-1000000000000000000 3-2 [| 
ОДО0000700"00000000 5ЕТОДОД00000000вВеаїь 00 


ти um 3 


Ө http://127.0.0.1/redis/hellosetget.php б, | Reader || 6 | з 
GREE: МА 


НИЕ 


EEA: | 
ET 








03-1 О00000000 





eoo 


Ө | – зов Вече (0 = 
[> [© iz7001/reds/helosemetphp € [cadea] (O> 
EKE ЕЕ o 


HEA 


ЖЕ: 








03-2 ОДО00000000 


00000 

<?php 

/ІПП Predis 00000000 

require './predis/autoload.php'; 

МИП Redis 

$redis= new Predis\Client(array( 
‘host’ => '127.0.0.1', 
port => 6379 


)); 
/ГПППЦПППППП SET ПОПОПОВО Redis [| 
if($ GET['name']) í 
5гед5->зеЦ пате", $ GET['name']); 
} 
/ІПП СЕТ ПОП Redis 00000 
$name = $redis->get('name'); 
?><!DOCTYPE html» 
<html> 
<head> 
«meta charset="utf-8" /> 
<title>[] LU Redisl |[ </title> 
</head> 
<body> 
<?php if ($name): ?> 
<p>000000<?php echo $name; ?></p> 
<?php else: ?> 
<р>000000000</р> 
<?php endif; ?> 
<hr /> 
<h1>000</h1> 
<form> 
<p> 
<label Ттог- "пате "> ПП < абе! > 
<input type="text" name="name" іа= "пате" /> 
</р> 
<р> 


«button type="submit">[][]]</button> 
</p> 
</form> 
</body> 
</html> 
ОООООО0000РНРОЋеаіѕ$0000Ргеаіѕ0Аеаіѕ0005.1000000 
Ргеаіѕ$Д000000000005.1000Ргеаіѕр00000000000000 
Кеаіѕ$П000000000Ргеаіѕр00000000000000001ҸСАОО00000 
П5гед!5-> пс! П)П 
200000 
ІМСВ key 
000000000000000000000000000000000000 Redis 000000 
0000 1\©А00000000000000000000000000 
redis» INCR num 
(integer) 1 
redis» INCR num 
(integer) 2 
обобобобобобобббдообобобОБОБООЗОБОБОПОйОКеет по 
000 


redis> SET Тоо lorem 
OK 
redis> INCR foo 
(error) ERR value is not an integer or out of range 
ОПООООБОБОПСЕ ТО 5 Е ТООПОБООО ле 00000000 
def incr($key) 

$value = GET $key 

if not $value 


$value = 0 
$value = $value + 1 
SET $key, $value 
return $value 
ПП Redis 1000000000000000000000000000000000000000 
обобобобобобобобОБОБОБОБОБООКей 5 о рр000000000гасе 


сопаїсіопр I! ПОДОДОДОДА ОВ 00000000000 incr 00000000000 
ООО0О00000000000000000000000000000075"0000000000000 
“6” 000 SET 000000000000000000000000000000007 67000000 
П“7”ППП1МСАПППППАВедї5ПППППППППаїотїс operation[] E! [TTD 
О0000000000000000000000000000000004.100000006000000 
0000000000 


3.2.3 Ц 


100000000 

ОДООД0О00000000000000000000000000000ро05200 
ІО:раде.міемО0000000000000000000013САО0000000000 

ПО Redis ПОООО0000000000000000000*0000:0010:0000"0 
О000000000Пизег: 1: пепаз 0001001 О0000000000000000000"7." 
О00000000000000Аеаіѕ=0000000000000000000000000 redis- 
cli ВПООО00000000000000000000000000000000000 ч:1:#0000 
000оѕег:1:ғіепаѕрО0000000000000000000000000000000000 
ОДООООД000000000000000000000000 

20000015 

000000000000000 ID 00000000000000000000 
AUTO ІМСКЕМЕМТ ДООООООО00О000000000000 1р 000000 


RedisQOO00000000 0000000000000 00000(0000):count_'*! 0000 
изегв:соип ОО000000000000000000000001МСЕКО0000000000 
ОДІМ СЕООДООДООО000300000000000 ІМСЕООДООООО000000000 
ОДОООО000000000000100 

30000000 

00000000000000000000000000000000000000000000000 
ОООД000000000000000000000РНРПО вегігіігеП)ауазсгір ПП 
ЈЅОМ.ѕігіпоіғурО0О000000000000000000000000000000000000 


О0МеѕѕадеРаск |61 П000000000000000000 

ПООСОООСООООСО0ОО0Аеаіѕ$8000000000 

Я 00000000 ID 

$postID = INCR posts:count 

Я ООООООООООООООООО 

$serializedPost = serialize($title, $content, фаш ог, 
$time) 

Я ОДООДОДОДОДО0000000000 

SET post:$postID:data, $serializedPost 

0000000000000000120420000000 

# O Redis 1000000 

$serializedPost = СЕТ post:42:data 

Я ОПОО00000000000000 

$title, $content, $author, $time = 
unserialize($serializedPost) 

# 000000000000 

$count = INCR post:42:page.view 


ОДОООО000000000000000000000000000000000000000000 
О0000000003.3.30000 


3.2.4 ППП 


100000000 

INCRBY key increment 

ІМСАВҮрО0ІҸСАКОБО0000000000000іпсгетепД000000000 
0008 

redis> INCRBY bar 2 

(integer) 2 

redis> INCRBY bar 3 

(integer) 5 

200000000 

DECR key 

DECRBY key decrement 

ОЕСЕДДДОІМСАЕОДОДОДОООООДО000000000 

redis> DECR bar 

(integer) 4 

П DECRBY О0000000000000000000ЕСАВҮ key 5 000 
INCRBY key -5П 

300000000 

INCRBYFLOAT key increment 

ИУСВВУРЕОАТОПОПИМСВВУ0О00000000000000000000 

redis> INCRBYFLOAT bar 2.7 

"6.7" 

redis> INCRBYFLOAT bar 5E+4 


"50006.69999999999999929" 

40000000 

АРРЕМО key value 

АРРЕМОДДОДОО0000матчедрдррдррордодороООматиероо00 
SET key матмеПДПОДОДОД000000000 

redis> SET key hello 

OK 

redis> APPEND key " world!" 

(integer) 12 

ПП key QUU"hello world! "ЦАРРЕМО ООООДОООДООО000000000 
DOnDdardaredis-eHr nba dau 

ЗО00000000 

STRLEN key 

5 ТЕСЕМОДООДОООООООДОДО000000000 

redis> STRLEN key 

(integer) 12 

redis> SET key ПД 

OK 

redis> STRLEN key 

(integer) 6 

О000000000000000000000000000000000000006еаіѕ= 000 
ОООУТР-800000000707070"000097Р-80000000300000000060 

6Q00000/000000 

MGET key [key ...] 

MSET key value [key value ...| 

MGET/MSET ПСЕТ/5ЕТ П0000МСЕТ/МЅЕТ QQ0000/0000000 
00008 


redis> MSET key1 v1 key2 v2 key3 v3 

OK 

redis> GET key2 

"2" 

redis> MGET key1 key3 

1) "v1" 

2) "v3" 

70000 

GETBIT key offset 

SETBIT key offset value 

BITCOUNT key [start] [end] 

BITOP operation destkey key [key ...] 

000008000000008е91$00040000000000000000000000000 
О0ғоорП0рагр 

геаіѕ> SET foo bar 

OK 

базПШП“Ы”“а”Ц“г”ПППА5СИПППП98П19 7011 40000000000 
(1100010911000019)111001 000 foofQ0000000003-3000 


b a r 


о [1 [1 [010 [0 [ро [о | 1[o[o[ojojrjo | | | [о (ото 


03-3 Баг 00000000 


СЕТВТПППППППППППШПППППППППППШППОП 1 пОПОВООВО 
redis> GETBIT foo 0 

(integer) O 

redis> GETBIT foo 6 

(integer) 1 


0000000000000000000000000000000000090 

redis> GETBIT foo 100000 

(integer) 0 

SETBIT О000000000000000000000000000000000000000 
коой аа ri n mre ООПО0000006000000700010 

redis> SETBIT Тоо 6 0 

(integer) 1 

redis> SETBIT foo 7 1 

(integer) 0 

redis> GET foo 

"ааг" 

ПППППППППППППППШПППППП5ЕТВ!ТПЦПШПШППППШПШППППОППП 
00000000000000000000000000000090 

redis> SETBIT nofoo 10 1 

(integer) 0 

redis> GETBIT nofoo 5 

(integer) 0 

впсофмтогообобобобобобзаббобободбро 

redis> BITCOUNT foo 

(integer) 10 

ОДОДО00000000000000000000000000007 аа ПП 

redis> BITCOUNT foo 0 1 

(integer) 6 

ВІТОРО00000000000000000000000009еѕёкеуроо00000 
ВГТОРПОППОПОПОППАМРПОВОХОВОМО ТООПООО 6 ааа ORE 
ПП 

redis> SET fool bar 


OK 

redis> SET foo2 aar 

OK 

redis> BITOP OR res foo1 foo2 
(integer) 3 

redis> GET res 

"car" 


0000003-4000 


b a r 
1001 
0011111010 0 10 0 1 10 О 0 О1 0111 0 0 1 0 
OR 
| a a r 
foo2 
|11 000010111 00 0ООо 1 0 1 1 1 0 0 1 0 
= 


| с а r 
res 
0 11110 0 0 1734101 1111010101 0 10111001 0 


03-4 OR 000000 
Redis 2.8.7000 ВІТРО50000000000000000000010000000 
"раг"ООДОО00000000000000000001 00000000000 
redis> SET їоо bar 
OK 


redis> BITPOS foo 1 

(integer) 1 

ОПОЗ-ЗПОПООООВГТРО 5ОПОПОПОО“ bar” 0000000100000000 
ОО1000000000ВІТРО$00000000000000000000000000000000 
ПОВІТРОЗ5 ВО0000000000000000000000000000000000000000 
ООО0О000000000000000000000000000000000000000"7 a "ET CE] 
ОО00000010000000000000000 

геаіѕ> BITPOS foo 11 2 

(integer) 9 

ОООО0Д0000000000000000000000000000000000000000000 
ОООО000000000000001000000009000000000000000000000000 
ОДОДОО00000 Redis ПО0000000000000090 

ОДООДООО000000000000000000000000000000000019000000 
ООООД00000000000000000000010000000000010000000000000 
001000р0000000000100 КВОДОООООООСЕєТВІТО5ЕТВІТОДООООО 
ПО(1)000000000000000 

ПП ПП SETBIT ДОДОДОДОДОДОДОДОДОДОД0О00000000веаїь 00 
ООО00000000000000000000000000000 ОО0000000000000000 
ООО000000000000000000000000000000201400МасВоок Pro [] 
000000000232-1000000 500 MB 0000000000 1 000000000000 
ООО0О0000000000000000000000000000000000000000001000 
100000001ПДО0000000100М8О00О000000000000001000 
100000000000000 


3.3 0008 


ППППППППППППППППППИПППППППШПППШППВоої5їгар[П1 3 00 
ООДОО0000000000000Н МЕДДООО0О00000000000 

0000000 

00000000000000000000000000000000000000000000000 
00000000000000000000000000000000000000000000000000 
0000000000000000000000000000 

ОО000000000000* 000" 0000000000000000000 

000000000000000000000000000000000000000000000000 
00000000000000000000006 

0000000000000000 

00000 Redis ОПООО00000000000000000000000000000000 
00000 


3.3.1 Ш 


00000000 Redis ПООПООПОПОООВОООПООБОВОПООВаза 0000 
Ороброррбр0000000бета орроороборороробооборороророробоб 
О00000000000000000000000000000000232-- 10000 

ПО 0000000Веа!5 ОООООООО0О00000000000000000000000 
ОДООО00000000000000 

ОО0000000000000000 1р ОрОДОДОО000000000000000000 
О000000100200000000000000соіо патеПрисейз 10000000 
000000000000000003-5000 





03-5 ПО00000000000000 
ОО000000000000000000000003-2000 
03-2 ПОДОООО000000000 


ID color name price 
l не, KH 100 7j 
2 не йн 90 7j 
3 ще па 600 Jj 
ООООО0000000000000000000000000000000000000000000 
00110 0 1 0000000000000000000000003-3000000 
03-3 00000000000“ 00" 


тр сојок name price date 


І же = 100 75 2012 *F. 12 H 21 H 
2 не RH 90 7j 
3 ше TRI 600 Fj 


Дріоргрзророробаавєерродоооообобобобрбобобо00000000 
ОО00000000000000000000АМ 181 ДОООООООООООБООООООВОПО 
ОДООООД000000000000000000000000000000000000000000000 


0000000000 
П Redis 10000000000000000000 3-5 00000000000000000 


[000000000008е91$00000000000000000000000000000000000000 


000000 
3.3.2 ПП 


1000000 
НЅЕТ key field value 


HGET key field 

HMSET key field value [field value ...] 

HMGET key field [field ...] 

HGETALL key 

НУЕТОООВОВОВОВОН@ЕТ000000000000000 

redis> HSET саг price 500 

(integer) 1 

redis> HSET car name BMW 

(integer) 1 

redis> HGET car name 

"BMW" 

HSET ОО00000000000000000000000000000000000000000 
ОДОб000000Оираасерододоріпвего ОПОДОДОДОООДОДОДОДО 
ПОНЅЕТООО001000000000000000000000095ЕТОО0000000000 
ООО000000Н5ЕТОО00000000 

ПП ОКеаіѕ$00000000000000000000 Н5ЕЄТОДОДОД00О0000000 
ЅЕТООО0000000000000000000000000000000000000000"ЕКА 
Operation against a key holding the wrong kind of value" 19! 
П 

ОООО000000000000000НМ5ЕТОДООДО0000000 

HSET key field1 valuel 


HSET key field2 value2 
ОООНМЉ5ЕТООООО 
HMSET key field1 value1 field2 value2 
ООООНМСЕТОД0ОД000000000000 
redis> HMGET car price name 
1) "500" 
2) "BMW" 
000000000000000000000000000003. 3. 100000000000000 
ООООООБОБООБООБПОБОБОНСЕТАН 0ООО 
redis> HGETALL car 
1) "price" 
2) "500" 
3) "name" 
4) "BMW" 
0000000000000000000000000000000 Redis 00000 
HGETALL ОДООООД00000000000000000000000000Модае.)500 
redis.hgetall("car", function (error, car) { 
//hgetall В00000000000 )әмазсгірі ПП 
console.log(car.price); 
console.log(car.name); 
}); 
2000000000 
HEXISTS key field 
НЕХТ5Т5ППППППППППППППППППШИПШПШИППОППППППШПШПП 
ОПП 
redis> HEXISTS car model 
(integer) 0 


redis> HSET car model C200 
(integer) 1 

redis> HEXISTS car model 
(integer) 1 

30000000000 

HSETNX key field value 


HSETNX H2! ПОДН5ЕТОДОООООДОООООООО00Н5ЕТМХОДООО 
ПИППППППИПППППИППИП 
def hsetnx($key, $field, $value) 
$isExists = HEXISTS $key, $field 
if $isExists is 0 
HSET $key, $field, $value 
return 1 
else 
return 0 
UUUHSE тмхообобоббободовово 
400000 
HINCRBY key field increment 
ООО0000000000000000001МСАВҮПНІМСКВҮрП0000000000 
О00000000000000 HINCR 000000000 НІМСЕВҮ key field 10000 
НІМСВВУПОДОДООО 
redis> HINCRBY person score 60 
(integer) 60 
ПОрегѕопоо000нІМСАВҮрО00000000005согеро500000000 
"О"ДрОДоб00000000000 
900000 
НОЕЇ key field [field ...] 


НРЕЄСОООООООООО000000000000000000 
redis> НОЕЇ car price 


(integer) 1 
redis> HDEL car price 
(integer) 0 
3.3.3 Ц 
10000000 


3.2.300000000000000000000000000000000000000 
000000000000000000000000000000000000000000000000000 
0000000000000000000000000000000000000000000000000 
000000000000000000000000000000000000000 

Ін ы АНЫ 


03-6 ПО00000000000000 


ОДООДО0000000000000000000000000000000000000000000 
ООО000000000000000000000003-7000 

003-70000000000000000003-60000000000000000000000 
0000 HGETALL 00000000000000000000000000000000000000 
ПО000000000000000000000000004.600000 

200000000 

000МУогаРгез5 ПДПООООООО0О000О00000000005149600000000 
ОДОД00000000000000000000000000000007 This Is А Great 
Post! "UUU0U0"this-is-a-great-post” QOQU00000000 0000000000 
ОО000000000000000000000000000000000000100 

at FR TB 











20125F9 818 
= 


[13-7 100000000000000 

обобобобободобяйча .о.іа00000000010000000000000000 
ООООО0О0000000000001000000000НЕХІ5 Т50000000000000 
НСЕТОО000000000001000 

ОДОО000000000000 

$postID = ІМСВ posts:count 

Я 0000000 slug 000000000000 

$isSlugAvailable = HSETNX slug.to.id, $slug, $postID 





if $isSlugAvailable is 0 
# slug ПООООООО000000 slug, 
+ ПООДО00000000 
ехії 
HMSET post:$postID, title, $title, content, $content, slug, 
$slug,... 
ОООООООН5ЕТМХООООООООНЕХ 5 ТЬОН5ЕТООООООО000000 
00000000000000000000000000$1ч9.6о ларооооо О 
$postID = HGET slug.to.id, $slug 
if not $postID 
print QOU00 
exit 
$post = HGETALL post:$postID 
print ППООО$ роз Ее 
О000000000000000000000000 slug.to.id О0000000000 20 
420000000Опем514900000 
# 0000 slug 0000000000000 
$isSlugAvailable = Н5ЕТМХ slug.to.id, $newSlug, 42 
if $isSlugAvailable is 0 
exit 
+ 0000000 
$oldSlug = HGET post:42, slug 
+ 0000000 
HSET post:42, slug, $newSlug 
+ 000000 
НОЕЇ slug.to.id, $oldSlug 


3.3.4 ШЦ 


100000000000 

НКЕУ5 key 

HVALS key 

ОООООД0000000000000000000000000Н КЕУ500000000 
redis> HKEYS car 

1) "name" 

2) "model" 
НМАТЗОДОНКЕУФЗОООООД0НМАЄЗЬОООООДОООДООООДОО 
redis> HVALS car 

1) "BMW" 

2) "C200" 

20000000 

НІЕМ Кеу 

000 

redis> HLEN car 

(integer) 2 


3.4 ПІ 


ОДООДО0000000000000000000000000000000000000000000 
ШШП 

ОДООО00000000000000 

e 10 ро$Е5: сочи ППТ 


e 0000 ID 00000000000000000 ID 000000000000001000 
ОО0010000000000п00001000000000010 ~ (п - 1) * 10"0"пах(0 
ПООО ID -n * 10 + 1, 1)"[] 

e ПО ПО НМСЕТПОО0000000 

обббородо 

# 0000 10 000 

$postsPerPage = 10 

Я 000000000 ID 

$lastPostID = СЕТ posts:count 

# $currentPage ППППППППППЦПП$сиггепїРадеЦППП 100000 

$start = $lastPostID - ($currentPage - 1) * $postsPerPage 

$end = max($lastPostID - $currentPage * $postsPerPage 
+ 1, 1) 
# 0000 1р 0000 
for $i = $start down to 5епа 
+ ПООДОО0000000000 
post = HMGET post:$i, title, author 
print $post[0] # 1000 
print $post[1] я ПООО 

ОООООБООБООБООООВБОВО ID ОООДО0000000000Е2Х15750000 
ООТБОДООД000000000000000000000000000000000000000000 
ОО0000001000000000000000000000019000000000000000000 
ПП 

ООООД000000"000000"0000000000000070000КЕУ50000000 
ПП КЕУ5ОО0О00007 розі "ОООООО0000000000" 

0000000“0000000КЕУ$00000000000000000000000000000 
ОДОДОДОО0О0Д0000000000 Redis ДОООО0000" 


3.4.1 П 


ОДО00п5:00О00000000000000000000000000000000000000 
00000 

Оробрбб0000000доцбіе linked listQO00000000000000000 
О0000(1)0000000000000000000000000000000000000000000 
ора0броб0000000002000000000000000020000000000000 

ОООО00000000000000000000 iPad mini 0000100000000 
ООД000000000000000000000000000000000000486 00000000 
Піраа тіпі0000000486 О000000000000000000000 486 00000 
ОДООООО000000000000000000000000000000000000000000000 
0000000006 

00000000000000000000000000000000000000000000000 
ПО0000000000000000000000000000000000100000000000000 
ОДОД0000000000001 )Д00000000000000000000000000000000 
000000000 

0000000Ае91$00000000004.40000000 

О000000000000000000000000000000232 = 10000 


3.4.2 П 


10000000000 

LPUSH key value [value ...] 

RPUSH key value [value ...] 
ЕРОЅНО00000000000000000000000000000 

геаіѕ> LPUSH numbers 1 

(integer) 1 
ООпитрегѕВО000003-8000.РОЅ5НОО0000000000000000 


redis> LPUSH numbers 2 3 
(integer) 3 
ГРУЗНОДООД0ОДОО"2"00000073"00000пипбег00000003-9 


000 Ш 


03-8 00001. П numbers ППППП 


ШІНШІ 


03-9 00002030 numbers 00000 
ППППППППППППИПЕРОБНЦППППППЕРОБНЦППГП 
redis> RPUSH numbers 0-1 
(integer) 5 
ОДпиплбег00000003-10000 


Е] 
03-10 ПП RPUSH Д0000000-10 numbers 00000 

20000000000 

LPOP key 

КАРОР key 

ПОО0ОЕРОРОО00000000000000СРОРПО0000000000000000 
ОбобоббОБОБОБОБООБОБОБООВОВО пипабегь 00000000000 
0"3"00 

redis> LPOP numbers 

"3" 

О0поитрюегѕ00000003-11000 

ПООКРОРОДООООООО0000000 


redis> RPOP numbers 
Mob 
ОДпиптобег500000003-12000 


О000000 4 0000000000000000000000000000000000000 
СРОБНОСРОРЦЕРО5БНЦОЕРОРЦОООООООООООООСРО5БНЦЕРОРЦ 


` [mi 


03-12 П0000000питоегѕ00000 


IBI 
03-12 ДОД0000Опупобегь 00000 

ЗОДО00000000 

LLEN key 

ОООООБЕГЕМООПОП 

redis> ШЕМ numbers 

(integer) 3 

LLEN 0000000500 SELECT COUNT(*) FROM 
table пате 0 LLENQQUQ0000(1)0000RedisQOU00000000000 
обообобобобблпооваооодМузо 2оабодобоббобобобобрдодо 

40000000 

LRANGE key start stop 

ГКВАМСЕППППППППППППППШППППППШПИПШПШППЦВААМСЕПЦПППП 
0000 start] зеорооеобобобоббобобобобобОБОБОбКеят 00000 
00090 

redis> LRANGE numbers 0 2 

1) 2" 








2) "1" 

3) "о" 

ЕКАМСЕПОО000000000000СРОРО0000000000КАМСЕВО000 
О00000000000005!ісерооо00-КАМСЕВПОО00000000000 
Јамазспр | 

var numbers = [2, 1, 0]; 

console.log(numbers.slice(0, 2)); //ПППІПІ2, 11 

ЕКАМСЕПОО0000000000000000000"= 1"00000000000"-2"р 
ОДО000000000000 

redis> LRANGE numbers -2 -1 

1) "1" 

2) "0" 

ОООСКАМБЕ numbers 0 -1 100000000000000000000000 

1000$а обойзтороабоообобобободдр 


2000stop 000000000000 00000000000 
redis> LRANGE numbers 1 999 


у" 

2) "0" 

S О000000000 

LREM key count value 

СВЕМООДОДООДООсомпдООматиедроббодб0Д0000000000000 
count[J[ IL IULREMII[ III IILI II IU II 

0100 count > ОП ЕКЕМ UUUUUUUUUUUUU count ПОП value[|] 
000 

0200 count < ОП LREM ПОПОПОВОВОВО сочи 000 value р 
000 

0300 count = ОП СВЕМООДООДОДОО valuerit 


redis> RPUSH numbers 2 
(integer) 4 

redis> LRANGE numbers 0 -1 
1) "2" 

2) "1" 

3) "0" 

4) "2" 

# О00000000000727000 
redis> LREM numbers -1 2 


(integer) 1 
redis> LRANGE numbers 0 -1 
1) "2" 
2) "1" 
3) "0" 

3.4.3 ПП 
1000001000 


О00000000000000000000р0о5:1і$#0001рО00000000000 
ЕРОЅ5НПО00000100000000000000000000000000010 00000000 
КЕМ posts:list 1 000000 ID 

0000 1200000000 СЕКАМСЕПООО0000000000000000 

$postsPerPage = 10 

$start = ($currentPage - 1) * $postsPerPage 

$end = $currentPage * $postsPerPage - 1 

$postsID = LRANGE posts:list, $start, $end 

Я 000000000000 ІРО0000000000000000 


for each $id in $postsID 
$post = HGETALL post:$id 
print ПОПОО$ post.title 
ПО О О UO 
ОббобобобеВвАмо Е О00000000000000000000000000000000 
000 
0000000000000000000000000000000000 МеЄТОДОД0ОООП 
000000000000000000000000001500000000000000000000000 


round-trip delay timeQ_4!_QQ000000000000000000000 

ОО000000000001р0000000000 

О1000000000000000000000000000 розе бо 00е тероооо 
0000000000000000565:115#1000000000000000000 

П20000000000000000000000000000000000000000000000 
ОДООрО000000000000000 

ОООО00000000000000000000000000000000000000000000 
ООО000000000000000000000000003.600000000000000001р00 
0000 

20000000 

ОДОО0О000000000000000000000000000000000000000000 
ООООДО000000000000000000000000000000000000000000000 
ОДООДО00000000000000000000000000000000000000000000 

000000000 воз 0010: сопоплепе ППООДОООО0О0000000000 
0000150420000000 

+ ОО00000000 

$serializedComment = serialize($author, $етай, $time, 
$content) 

LPUSH post:42:comments, $serializedComment 


DODIDDOBBIDUE RANG ETITEIDOBBDBUDUDOUBUO 


3.4.4 ПП 


1000/0000000000 

LINDEX key index 

LSET key index value 

LLLILILILILILILILIL ILILILILILINDEXIII II II L IILI ILINDEXIILILILILILIILIII I 
0000060900000 

redis> LINDEX numbers 0 

"д! 

П0іпмаехро000000000000000000000000= 10000 

redis> LINDEX numbers -1 

"0" 

ЕБЕТОСОООООБОООБОБОБОБОБОО ® Чех ооррПмайиерррйп 

redis> LSET numbers 1 7 

OK 

redis> LINDEX numbers 1 

"7" 

20000000000 

LTRIM key start епа 

LTRIM ОебообобоббобоббаООООООБОБОБООООСВАМСОЕДООПО 
00008 

redis> LRANGE numbers 0 -1 

1) "1" 

2) "2" 

3) "7" 


4) "3" 

"0" 

redis> LTRIM numbers 1 2 

OK 

redis> LRANGE numbers 0 1 

172727 

2) "7" 

СТВІМОДООІРОУ5НОДООООООДОООООДОДОДООДО0000000000 
001 09000000000000000000/20ТАІМОДОО 

LPUSH logs $newLog 

LTRIM logs 0 99 

3000000000 

LINSERT key BEFORE|AFTER pivot value 

LINSERT 00000000000000000 pivot О0000000000000 
BEFOREQUAFTER OOO value 0000000000000 

ИМЅЕАТОО000000000000000000000 

геаіѕ> LRANGE numbers 0 -1 

1) "2" 

2) 7" 

3) "о" 

redis» LINSERT numbers AFTER 7 3 

(integer) 4 

redis»? LRANGE numbers 0 -1 

1) "2" 

2957" 

3) "3" 

4) "0" 


redis> LINSERT numbers BEFORE 2 1 
(integer) 5 
redis> LRANGE numbers 0 -1 
1) "1" 
2) "2" 
3) "7" 
4) "3" 
5) "О" 
АПОО0000000000000 
RPOPLPUSH source destination 
ВРОРЕРУЗНИПИОИНПВОВОВООВОВОВОВОООСОВРОРОПОПВ 
ГРУЗНОДОВРОРІРО5НОДОДОвЗОМгсе ПООООООО0Д000000000000 
аеѕііпаєіопоуО000000000000000000000000000000000000000 
def rpoplpush ($source, $destination) 
$value = RPOP $source 
LPUSH $destination, $value 
return $value 
ОПОО00000000000АРОРЕРОЅН ПО000000000000000000 
ѕоигсеђаеѕїіїпаїоп00АРОРЕІРОЅНП00000000000000000000 
ООООДО000000000000000000000000000000000000000 
RPOPLPUSH ООО0000000000000000008РОРЕРОЅНПО00000000 
ОДООДО00000000000000000000000000000000000000000000 


3.5 0000 


00000000000000,„00000000000000000000000000000000 
000000000000000000000000000000000000000000000 
Ке91$00000000%а900000000000000000000000000000000000000 
0000000000 Кей в р Оробб000000000000000000000000000000 
ОДООО000000000000 

0000000000000 

О0000000000000Аеаіѕ ВОО00000000000000000000000 


3.5.1 Ш 


ОДОООО000000000000000000000000000000000000005ей 
0000000232 — 1000000000000000000000000 
ОДО00000000000000000000000000344000 


03-4 ОДОО0000000 
ажы 5| ж = 





f iñ AE 2% 2°-1 ХН BS 2° а 
E FETE б ДЕ 
ЩЕ — Жж її 
ДороророророборододордорорродододоробродоророОвеаїьоб 
00000000000бази ё#абіероо00000000000000000(1)000000000 


ОДООООО00000000000000000000000000000000000 


UN 


3.5.2 П 


1000/0000 

SADD key member [member ...] 

SREM key member [member ...] 

SADD О00000000000000000000000000000000000000000 
ООООДО000000000000000000000000000000000000000000000 


ОДО0000000000000 

redis> SADD letters а 

(integer) 1 

redis> SADD letters a b c 

(integer) 2 

О005АРОЦ000000200000*а”О000000000000000000 

ЅАЕМОБО00000000000000000000000000000 

redis» SREM letters с d 

(integer) 1 

0000“ а” В000000000000000000000010 

200000000000 

SMEMBERS key 

УМЕМВЕВ5ПОДООДООО000000000 

redis> SMEMBERS letters 

1) "b" 

2) "а" 

300000000000 

SISMEMBER key member 

0000000000000000000009(1)0000000000000000 
515 МЕМВЕ КОПООООООБОБОБОБООВО 515МЕМВЕВООООІ ОД00000 
О00000000000 

геаіѕ> SISMEMBER letters а 

(integer) 1 

redis> SISMEMBER letters а 

(integer) 0 

4000000 

SDIFF key [key „] 


SINTER key [key ,,] 

SUNION key [key „] 

0000000300000000000000000 

1105 О1ЕРООООООБОБОБОБОБОБОББАОПОВОПОПОПА-- ВО0000000 
Р сини r ={х | хелохев [ILU] 


03-13 ППППППППА-В 
{1, 2,3} - (2, 3, 4} = {1} 
{2, 3, 4} - (1,2, 3} = {4} 
о РІРРОООООО0000 
redis> SADD setA 1 2 3 
(integer) 3 
redis> SADD setB 2 3 4 
(integer) 3 
redis> SDIFF setA setB 
1) "1" 
redis> SDIFF setB setA 
1) "4" 
5 РІРРОООООДОО0000000 
redis> SADD 5еїС 2 З 
(integer) 2 


redis> SDIFF setA setB setC 

1) "1" 

00000000 setA - 5$е*вЦППППППП 5еєс0)000 

1215! МТЕКОООООООООБОООБОПОБАОПОВОБОПОПА п ВО00000 


ОДА ОДО0В000000000003-1400000А п B ={x | x € A Dx ЄВ 


00 


{1, 2, 3} п 42,3, 4} = 12, 3) 

ЗІМ ТЕВООООД000000 

redis> SINTER setA setB 

1) "2" 

іа: 

ЅІМТЕАЦОО000000000000000 

redis> SINTER setA setB setC 

1) "2" 

2/2. 
ПЭПБОМЮОМПППППППИПИОПОГГПГППАПИПВПППГППАӘВПППГП 


ОДА 0008000000000003-150000АУВ -4х | хЄАПх €B}0000 


{1, 2, 3} u{2, 3, 4} = {1, 2, 3, 4} 
A B 
| | 


АПВ 
03-14 ПОДОДОДОА п В 





03-15 ППОООООДА о В 
5УмММ0000000000 
redis» ЗУМОМ setA зе В 
1) "1" 
2) "2" 
3) "3" 
4) "4" 
ЗОМ'ОМООДО00000000000000 
redis> SUNION setA setB setC 


1) "1" 
2) "2" 
3) "3" 
4) "4" 
3.5.3 ПП 
10000000 


ОДООО0000000000000000000000000000000000000000000 
00000000000 
О000000000роѕ:0010:#а9ѕ000000000000000000000 


# 010 [] 42 00000000 

SADD post:42:tags, ППІП, 0000, Јама 

# 00000 

SREM post:42:tags, [ODO 

# 0000000: 

$tags = SMEMBERS post:42:tags 

print $tags 

ОДОДОДО00000000000000000000000 МуогаРге5< Д000000 
ООДОДрОО0000000000000 3-16 ПОООООООБОП5АОБО5КЕМООООО 
LIE] 

ОООДО000000000000000000000000003-1 700000000000000 
ООООО00000000000000000000000000000000000000000000000 
0000000000000000000000000000000 


Tags 


Add 


Separate tags with commas 
RE Sit жі зл 


Choose from the тобі used taqs 


03-16 WordPress 0000000 


НІЖИН: |н; Возни; ЋЕ 
2 


ИШ: ВИК; Mes. BEF 
| ая | 
03-17 0000000000 
ООООО00000000000000000 Redis 0100000000000000000 
3.4 100000000000000000000000000000000000000000000 


20100000000 
ОДОООД000000000000000000000000000000000000000000 
ОДООДО000000000000000000 
0030000роѕё$Пёадѕ[роѕёѕ кад5 ОООДПОООО000О0000000000 
000000003-5003-6003-7000 
03-5 posts ППП 


T RA м ЯВ 
post_id хм ID 
post title У ES fp Î 

03-6 tags ППП 

т É А я В 

tag_id r ID 

tag_name bn EK 

03-7 posts tags ППП 

т RA я ЕҢ 

роз іа MA SCH ID 

tag_id ХУ КЖ: ID 


О0000000 Јама" “музо "Кейт" D] 30707] 7 n add ds er 
000 
SELECT p.post title 
FROM posts_tags pt, 
posts p, 
tags t 
WHERE pt.tag_id = t.tag_id 
AND (t.tag_name IN ('Java', 'MySQL', 'Redis')) 
AND p.post_id = pt.post_id 
GROUP BY p.post_id HAVING COUNT(p.post_id)=3; 


0000000000 SQL ороооооооовоооооооооооро«еа 5 0000 
0000000006 

ООО0000000000000ао:0000:роѕЕѕ0000000000000000100 
0000000300001000010203000100100000077ама"ої 0 2 0000 
009ама"0"Му5ОСОО 0 з 000000ама"0"Му5оСО"Кеаїз"000 


0000000000003-1800.421 0 
# жав 


к=» jel ке] 
юз» робо ке | ше | 
маси рон ^ |) 
De ]—[ = | 
03-18 [0100000000000 
00000000000“ МУуЗОР'ООДООО000000000 SMEMBERS 
{ад:МуОЕ:ро$Е$ППППЕППОИВООО Шама My ОШ Веа! 3 О0000 


ОПОПОПОЕад :Јама:роѕ 5 Пад: M/SQL:posts[]tag:Redis:posts[]3[][] 
ПООООО$ИМТЕВООПОООО00 


3.5.4 ШЦ 


10000000000 

SCARD key 

УСАКРООООООООООООО0О0ОООО 

redis> SMEMBERS letters 

1) "b" 

2) "а" 

redis> SCARD letters 

(integer) 2 

2000000000000 

SDIFFSTORE destination key [key ...] 

SINTERSTORE destination key [key ...] 

SUNIONSTORE destination key [key ...] 

5РІРРУТОКЕДДОЗОТРРБОДООДОСОООООДООООООО00000000000 
UUUUUdestination ДОД 

5РІРРУ ТОКЕДДОООООООДООООО00О00000000000000000000 
0008 

УМТЕК$ТОКЕП$УМОМ$ ТОВЕДОДОООДбОДООО 

300000000000 

SRANDMEMBER key [count] 

SRANDMEMBERQQQUU000000 00000000 

redis> SRANDMEMBER letters 

на” 

redis> SRANDMEMBER letters 

"p 

redis? SRANDMEMBER letters 

"a" 


Ор00Осочпедорб00000000000Осочпі000000000000 


0100сочп О0005КАМОМЕМВЕАКЦО0000000сочп 00000 
ПО00соипОО000000000005КВАМОМЕМВЕАЦО0000000000 

020сочп ПОПОПЗКАМОМЕМВЕКООПООООО «очи 1000000 
ОДО0000000 

ОО0000000еёкегѕ$0000000000 

redis> SADD letters с d (integer) 2 

UU letters ОДО0О"а"076"0"с"О"а"а ПППШШПШШПШШП 
5ҺВАМОМЕМВЕАВЦПЦППППП 

redis> SRANDMEMBER letters 2 

1) "а" 

дс: 

redis> SRANDMEMBER letters 2 

1) "а" 

2) "b" 

redis? SRANDMEMBER letters 100 

1) "b" 

2) "a" 

3) "с" 

4) "d" 

redis> SRANDMEMBER letters -2 

1) "b" 

2) "b" 

redis? SRANDMEMBER letters -10 

1) "b" 

2) "b" 

зу 

4)"с" 


5) "b" 

6) "a" 

7) "b" 

8) "d" 

9) "b" 

10) "b" 

0000000000 SRANDMEMBER [1000000000000000000 
SRANDMEMBER letters -100000000000000000000 000000000 


00 931 ПООО00000000000000000000000000000000000000000 
ОООД000000000000(0)000000000000000000000000006000000 
ОСООООБООООПОООООБООПОПОПОПбиске nim p ab pm ma d 
ОрО00065000000000000000 БО000000000000000000000Аеаіѕ 
ОДОООО000000000000000000000000000000000000000000000 
О000000000000000005ААМОМЕМВЕВКОПОО000000000000 
КеаіѕПОООО0000000000000000000000000000000000000000 
О000000000000000000000003-19000 


2) 2,2) 


03-19 Redis 0003 О00000000000000000000000000000000 
060000000 
41000000000 


SPOP key 
З.АПООСОООЕРОРОО00000000000000000000000000000 
ЅРОРЦО0000000000000000000000000 ЅРОРО00000000000000 

000000 
redis> SPOP letters 
при 
redis> SMEMBERS letters 
1) "а" 
2) "c" 
3) "d" 


3.6 ШШШ 


ОДОД0000000000 Redis ВПООО000000000000000000000000 
ОДООО0000000000000 

ООДОО0000000000000000000000 19 О00000000000000000 
ОДООООО00000000000000000000 

0000000 

00000000000000000000000000000000000000-——00006 


3.6.1 ПП 


0000000$огееа $е010000000000000000000000000000000 
07007000 

ОДООДО0О000000000000000000000000000000000000000000 
ООООО00О000000000000000000000000000000МОДООО00000000 
ОДОДООО0000000000000000000000000000000000 


ОДООО0000000000000000 

01100000000 

020000000000000000 

ОДООД00000000000000000000000 

ОЗ ПОДОД0О000000000000000000000000000000000000000 
ООДО000000000700070700"00000000000000 

Д2гГ0000000000000000005кір Іі 000000000000000000000 
О00000000000(1о9(№))00 

ОЗОДОДООДО0О00000000000000000000000000000000 

П400000000000000000 

о0000000000Веаї 5 СОООООО000000000000000000000000 
0000 


3.6.2 П 
100000 


ZADD key score member [score member...] 

ZADD П00000000000000000000000000000000000000000 
ОД00007АРФ2О0000000000000000000000000000000000 

ОДОДОДОД000000000000ТопоПРеєег)Оаміа n n m d 


89006700100000 
redis> ZADD scoreboard 89 Tom 67 Peter 100 David 


(integer) 3 
ОПООООРеге ПППШППППППППППП76ЦППППП4АРОЦПППРеїеп] 


000 
redis> ZADD scoreboard 76 Peter 


(integer) 0 


ОО000000000000000000 
геаіѕ> ZADD testboard 17Е+307 a 


(integer) 1 

геаіѕ> ZADD testboard 1.5 b 

(integer) 1 

redis> ZADD testboard +inf c 

(integer) 1 

redis> ZADD testboard -inf d 

(integer) 1 

ОДУніпбО- пООДОД0000000 

200000000 

ZSCORE key member 

ШШШПП 

redis> ZSCORE scoreboard Tom 

"89" 

3000000000000000 

ZRANGE key start stop [WITHSCORES] 

ZREVRANGE key start stop [WITHSCORES] 

/ВАМСЕПООООДООООДОС0О0О0000000 start ]stopi 0000000000 
ПЦППППП/ВАМСЕЦПППВАМСЕППППШППППШПППОППППППШПШЇПШЇП 
0--1000000000000000 

redis> ZRANGE scoreboard 0 2 

1) "Peter" 

2) "Tom" 

3) "David" 

redis> ZRANGE scoreboard 1 -1 

1) "Tom" 


2) "David" 

ПОООСООООО00000000 ZRANGE 0000000 WITHSCORES [| 
ОО000000000007001, 002, ,, don" 000“001, 001, 002, 002,,,0 
Оп, 00n” 0000 

redis> ZRANGE scoreboard 0 -1 WITHSCORES 

1) "Peter" 

2) "76" 

3) "Tom" 

4) "89" 

5) "David" 

6) "100" 

2 ВАМС ЕООДОДОДОДО(Іод п-+т1)00090000000000970000000 
000 

ОБОБОБОБООООКей 5 ПО 0О00000"70" <" 9" <"А"<"2"<"а" 
«72"ЮОООО0000000000000000000000000000000000000000000 
ОДУТЕ-8000 

redis» ZADD chineseName 0 [00 ПО 1000 ПП 

(integer) 4 

redis> ZRANGE chineseName 0 -1 

1) "\xe5\x88\x98\xe5\xa2\x89" 

2) "\xe5\x8f\xb8\xe9\xa9\xac\xe5\x85\x89" 

3) "\xe8\xb5\xb5\xe5\x93\xb2" 

4) "\xe9\xa9\xac\xe5\x8d\x8e" 

ПО00Аеаіѕ$д00000000000000 

2ВЕУВАМСЕППП27ВАМСЕППППППП27ВЕУ/ВАМСЕПППППППППП 
ООО000000000 

4000000000000 


ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT 
offset count] 

ZRANGEBYSCORE О0000000000000000000000000000000 
ОО0ОбготтлахоодойбтотОплах 0000 

redis> ZRANGEBYSCORE scoreboard 80 100 

1) "Tom" 

2) "David" 

00000000000000000000000“ (7000000000078000100000 
000008900000019900000000000000000 

redis> ZRANGEBYSCORE scoreboard 80 (100 

1) "Tom" 

піпдизахододор00220000000-іп50-ніпТОО0Д00000000000 
000000000089000008900000000000000000000000000000000 
00000000000000000000000000000000+1900 

redis> ZRANGEBYSCORE scoreboard (80 +inf 

1) "Tom" 

2) "David" 

WITHSCORESII[JLIULIIZRANGEII[ IILI 

ПП SQL 000000 LIMIT offset count 00000000000 LIMIT 
offset count [] SQL ПО0000000000000000000000000#е000 
ОД0000ОсочпеороророророрОьсогебоатаородро00000 

redis> ZADD scoreboard 56 Jerry 92 Wendy 67 Yvonne 

(integer) 3 

ПЮзсогебоагай UI IL ILII 

redis> ZRANGE scoreboard 0 -1 WITHSCORES 

1) "Jerry" 

2) "56" 


3) "Yvonne" 

4) "67" 

5) "Peter" 

6) "76" 

7) "Tom" 

8) "89" 

9) "Wendy" 

10) "92" 

11) "David" 

12) "100" 

00000006900000000003000 

redis> ZRANGEBYSCORE scoreboard 60 +inf LIMIT 1 3 

1) "Peter" 

2) "Тот" 

3) "Wendy" 

000000000000000 100 000 3 0000000000000 
ДСВЕМВАМСЕВУБЗСОВЕПДОПОООДОДОООСВАМСЕПОО2ВЕМВАМСЕП 
00000000000000000 ZREVRANGEBYSCORE ОООООО0000000 
ZREVRANGEBYSCORE [1[1]00000000000000000000000000 ming 
глах ПОПЕ ВАМСЕВУ5СОВЕДООООООО0000 

redis> ZREVRANGEBYSCORE scoreboard 100 0 LIMIT 0 3 

1) "David" 

2) "Wendy" 

3) "Tom" 

S О000000000 

ZINCRBY key increment member 

ZINCRBY [100000000000000000000000000000 Јеггура00 


redis> ZINCRBY scoreboard 4 Jerry 
"60" 
іпсгетеп000000000000000еггура00 
redis> ZINCRBY scoreboard -4 Jerry 
"56" 


ПОООООБОПООКеат ПОООООООО00000000000 o 000000 


3.6.3 ПД 


1000000000 
ОПООООООООООООоОООоООоООооООоооооооорооооо000000 ID ПО 
ОДООО000000000000000000000Прозіз:раде.міемУ ОДО0000000 
ППППППППИП ZINCRBY posts:page. view 1 UU РПООООО 
ОДОО0000000000000000000000000000000 
$postsPerPage = 10 
$start = ($currentPage - 1) * $postsPerPage 
$end = $currentPage * $postsPerPage - 1 
$postsID = ZREVRANGE posts:page.view, $start[]|$end 
for each $id іп $postsID 
$postData = HGETALL post:$id 
print ПОПОПЗ ро Вафа. Ще 
003.200000000000Про5і:0010:раде.міемУ ОДООО000000000 
00000000000000000000000000 ZSCORE posts:page. view ПП 
ID 0000 
200000000 
З.АПОО0000000000000010000000955:1і5%0000000000000 
ООООД000000000000000000000000000000000000000000000 


ОДООООО000000000000000000000000000000000000000 
ООДОО0000000000000000000000000000000000000000100 


ОДОО0000000000Упіхо AA ПОООООООООООООООООБООВОПО 
0000 ZREVRANGEBYSCORE О00000000000000000000000 
О00000000%огаргеѕ5800000000000 


3.6.4 ШЦ 


100000000000 

ZCARD key 

ПО 

redis> ZCARD scoreboard 

(integer) 6 

2000000000000000 

ZCOUNT key тіп тах 

000 

redis> ZCOUNT scoreboard 90 100 
(integer) 2 

2 СОЦМ Питах  ПОПП02 КАМСЕВУ5СОКЕЦ ОООПО 
redis> ZCOUNT scoreboard (89 +inf 
(integer) 2 

30000000000 

ZREM key member [member ...] 
2КЕМОПО0000000000000000000000000000 
геаіѕ> ZREM ѕсогероага Wendy 

(integer) 1 

redis> ZCARD scoreboard 


(integer) 5 

41000000008 

ZREMRANGEBYRANK key start stop 

ZREMRANGEBYRANK ППППППППППППППППППП 9000000000 
ООООДО0000000000000000000000 

redis> ZADD testRemla2b3c4d5e6f 

(integer) 6 

redis> ZREMRANGEBYRANK testRem 0 2 

(integer) 3 

redis> ZRANGE testRem 0 -1 

1) "d" 

2) "е" 

3) "f" 

S О0000000000 

ZREMRANGEBYSCORE key min max 

2 КЕМВАМСЕВҮЅСОКЕЦП000000000000000000тіпОтахр 
ПО02ААМСЕВҮЅСОКЕПОО000000000000000000 

геаіѕ> ZREMRANGEBYSCORE testRem (4 5 

(integer) 1 

redis> ZRANGE testRem 0 -1 

1) "а" 

2) "f" 

600000000 

ZRANK key member 

ZREVRANK key member 

2 КАМКОО0000000000000000000000000000000000000000 
090000 


redis> ZRANK scoreboard Peter 

(integer) 0 

2 КЕМКАМКО000000000000000000 

геаіѕ> ZREVRANK ѕсогероага Peter 

(integer) 4 

7000000000 

ZINTERSTORE destination numkeys key [key ...] 
[WEIGHTS weight [weight ...]] [AGGREGATE 

SUM|MIN|MAX] 

21МТЕКЅ5ТОКЕЦО000000000000000000009еѕіпайопро000 
О000000000000009еѕёіпаіопр0000000 

destination DO0000000AGGREGATEQODODODO0O 

ПО: ППАССКЕСАТЕПДЗОМОООООПОПОПЯезипаноп  ПООППОПО 
обедобббобоббоббддддр 

redis> ZADD зогедбе 1 Та 2 b 

(integer) 2 

redis» ZADD sortedSets2 10 a 20 b 

(integer) 2 

redis> ZINTERSTORE sortedSetsResult 2 sortedSets1 
sortedSets2 

(integer) 2 

redis> ZRANGE sortedSetsResult 0 -1 WITHSCORES 

1) "а" 

2) "11" 

3) "b" 

4) "22" 


OD20UAGGREGATEQMINQUdestinationQQQ000000000000000 


0000000000000 


redis> ZINTERSTORE sortedSetsResult 2 sortedSets1 


sortedSets2 AGGREGATE MIN 


(integer) 2 

redis> ZRANGE sortedSetsResult 0 -1 WITHSCORES 

1) "а" 

2) "1" 

3) "b" 

4) "2" 
ПЗППАССКЕСАТЕЦ МАХ Паезпаноп  ОООПОПОООПОПОПО 


0000000000000 


redis> ZINTERSTORE sortedSetsResult 2 sortedSets1 


sortedSets2 AGGREGATE MAX 


(integer) 2 

redis> ZRANGE sortedSetsResult 0 -1 WITHSCORES 

1) "а" 

2) "10" 

3) "b" 

4) "20" 

СІМТЕВ5 ТОВЕПОДОООДУУЕТеНИТЬОПООООО000000000000000 


ОДООО000000000000000 


redis> ZINTERSTORE sortedSetsResult 2 sortedSets1 


sortedSets2 WEIGHTS 1 0.1 


(integer) 2 
redis> ZRANGE sortedSetsResult 0 -1 WITHSCORES 
1) "a" 


2) "2" 

3) "b" 

4) "А" 

0000000007 МТЕН5ТОКЕОООООООООО 2 МОМ5ТОВЕООООО 
ИШЕ 


ПО 
[1]. П“ПууогаРгес5 ДП" LI: WordPress 





[6]. MessagePack П JSON [|[|TILILILILI ILILILILILILIILILILII I ILILILILI I ILILILI I ILILILILI IL ILILILILI III 
MessagePack http://msgpack.org[] 

[7]. http://twitter.github.com/bootstrap[] 

[8]. [JObject-Relational Mapping 0000000 

[9]. 00000000000000S E TL ИШИНИ ШИШИП 

[10]. HSETNX ПП“ NX"[T]"if Not eXists" 

[11]. 4.5 0000000000000 











[14]. Unix UTC 501970 [11 []1 10 До 00 1970 
Unix[]1970 


Пай ПП 


ОООО000000000000000000000000000000000Веаї5000000 
О00000000000000000006еаіѕП0000000000000000000000000 
000,, 

Оробр000000Веаїз р00Кеаїв ДДОоробОООДОДОб0000000000 
LI RedisD 00000 


4.1 | 


ОДОДОО000000000000000000000000000000000000000500 
ООООД0000000000000000000000000000000000000000000000 
ОДООДО000000000000000000 

ОДОООО000000000000000000000000000000000000 
"Powered Бу Redis” ППООООООО0000000000000000000 

ОДОДОвеаї о ДОД0000000 

ОДОДОД0000000700"0"0007000000000Веаї роброродордодо 
ОДОДОООД0Д0О000000000000007 чвег: ПО :follewers"[]" изег: 
[]ID:following "ООО000000000000000000000000 

def follow($currentUser, $targetUser) 

SADD user:$currentUser:following, $targetUser 
SADD user:$targetUser:followers, $currentUser 


ПО 01000А 00010 020008000000 follow(1, 2)0000000000 
О00000000000000000000000000Аеаіѕ=0000000000000000000 
ОООО0000000000000000000000А000000000000000000800800 
ООО0000000000А00000000А000008000080*00” 00000 АЙВШ 
ОДООО00000000000000 

ОДООО00000000000000000000000070000000000000000 
оо 000000000000 

О00000Аеаіѕ= 00000000000 


4.1.1 ПП 


Кеаіѕ$В0000гапѕасёіопуоо0000000000000000 Redis 0000 
ООООО00000000000000000000000000000000000000А40800000 
ООДАОСОДОООООО00О0ВООООООООО000О00000000000000000000000 
ООООДО000000000000000000000000000 

обобобобобобоббббобОкеа 5 ПОПОПКей 5 00000000000 

redis> MULTI 

OK 

redis> SADD "user:1:following" 2 

QUEUED 

redis»? SADD "user:2:followers" 1 

QUEUED 

redis» EXEC 

1) (integer) 1 

2) (integer) 1 

ОДОДОДОДОО0Д00О0000000МУЄГІООООВеаїс О"ДОДОООДО0000 
ОО000000000000000000000”Аеаіѕ00*оКкр” 


000000000 ФАБОПОООООООООБОВОБОВПО Redis ДООО000000 
LLIIILILILIILIQUEUEDIII II IILI LIL ILILI LIL ILII I 

ОООО000000000000000 Redis ПОПОПО EXEC [I ILIIRedis[I[! 
0000000000000000000000О ЧЕЈЕРРООООООООООООООЕХЕС ПП 
ОДООООО000000000000000000000000000 

Кеа ППОДОООДО000000000000000000000Е2ХЕСОДОДОООП 
000 Redis ООДООООДО0000000000000000000000ЕХЕСОДОДОО 
ОООД00000000000000000000Веаїв Доро0О000000000 

00000Веа!$ ОДООООО000000000000000000000000000А00 
ПООО00000000В000000000000000000008000000000000А0000 
ОДООД00000000000000000000 


4.1.2 [| 


ООООО000000000000000000000Аеаіѕ 010000000000000000 
ОДО000000000000000 

01 О00О0000000000000000000000000000 

redis> MULTI 

OK 

redis> SET key value 

QUEUED 

redis> SET key 

(error) ERR wrong number of arguments for 'set' 
command 

redis? ERRORCOMMAND key 

(error) ERR unknown command 'ERRORCOMMAND' 

redis> EXEC 


(error) EXECABORT Transaction discarded because of 
previous errors. 

ООМОУСТІОООбОООЗОДОООО0О0О0000000000000000000000000 
О00000000000000000 EXEC 000 Redis ОО00000000000000000 
0000 

0000 Redis 2.6.5 ОПООООООО000000000000000000000000 
000000005ЕТ key мачеППППЕХЕСПОО0000000 

1) OK 

П20000000000000000000000000000000000000000000000 
00000000 Redis ПОПОПОПОВОВОВОБОВБОВОВ Redis ООООО000000 
ООООДО000000000000000000000000000000000000000000 

redis> MULTI 

OK 

redis> SET key 1 

QUEUED 

redis> SADD key 2 

QUEUED 

redis> SET key 3 

QUEUED 

redis> EXEC 

1) OK 

2) (error) WRONGTYPE Operation against a key holding 
the wrong kind of value 

3) OK 

redis> GET key 

"3" 

0000 SADD key 200000000 SET key 3000000 


Аеаіѕро0000000000000000го!юаскр {2 ВОО000000000000 
ОДОООО0000000000000000000000000 

0000 Redis 00000000000 Redis ОДОДОООООД000000000000 
ОДОДООО0000000000000000000000000000000000000000000 
ОДООООО0000000000000000000000000000000 


4.1.3 ММАТСНПППП 


ООООО0000000000000000000000000000000000000000000 
ОООО00000000000000000000000000001МСАКОО00000006ЕТр 
ЅЕТОО0О000іпсОООООООООО00000 

def incr($key) 

$value = GET $key 
if not $value 

$value = 0 
$value = $value + 1 
SET $key, $value 
return $value 

ОДОДОДОД0000000000і псгобОбОДОДОбОДбОД00О000000000000 
ПОО000000000000000000000000000000000005ЕТОО00000 
СЕТООО00000000000100000 

0000000000000000000006Ет000000000000000000000006 
ООООДО0000000000000000000000000000000000000000000000 
ООООМАТСНОМАТСН ОДОООООООО00О00000000000000000000000 
ООООООБОВОБОБО EXEC 00000000000 EXEC 0000000000 MULTI 
ОООООООУУАТСНОПОПОВОВО 

redis> SET key 1 


OK 
redis> WATCH key 
OK 
redis> SET key 2 
OK 
redis> MULTI 
OK 
redis> SET key 3 
QUEUED 
redis> EXEC 
(nil) 
redis> GET key 
при 
000000 ммАТСНОДОДОДОДОЛОДКеу 000 SET key 200000000 
0000 SET key ЗПОООДЕХЕСДООДОДОП 
ОООМуАтснобообобобобобистаоббобобро 
де? incr($key) 
WATCH $key 
$value = GET $key 
if not $value 
$value = 0 
$value = $value + 1 
MULTI 
SET $key, $value 
result 2 EXEC 
return result[0] 


ОДЕХЕСОДООООО0О000000000000гез ult[ О'00000000000 


ПП О0М/АТСНООО0000000000000000000000000000000000 
ППППППППППППППППППЕХЕСЦПППППППШШПШШПП 
ПП EXEC ОДПООООООДО000000О0000000000000009 МУАТСНО 
О00000000000000һѕеєххо00000Н5ЕТМХОр0000000000000000 
обедобабобобобобббоббододр 
def hsetxx($key, $field, $value) 
WATCH $key 
$isFieldExists = HEXISTS $key, $field 
if $isFieldExists is 1 
MULTI 
HSET $key, $field, $value 
EXEC 
else 
UNWATCH 
return $isFieldExists 
ОДОО0О0000000000000000000000000000000000000 
ОММ/АТЄНООДООООООДО0000000000 


4.2 1000 


ОДООД00000000000000000000000000000000000000000000 
ОДОООО0000000000000000000000 
ОДО00000000000000000000000700007ПРеадцезі 
тео ДООООООООООООООО0О000000000000 
ОДООД0000000000000000000 


ОДООО0О000000000000000000000000000000000000000000 
ОО00000000000000000000000000000000000ІРОО0000000000 
00 

ОО0000000000000000000000000000000000000000Аеаіѕр 
0000, „ 


4.2.1 (ТІП 


ООООДД0000000000000000000000000000000000000000000 
ООООДО00000000000000000000000000000000000000000 
ведї 0000 ЕХРІКЕОДОДОДОДОДОДОДОДОВеаї 000000 

EXPIRE ДОПОПОПО EXPIRE key seconds[][][] seconds 00000 
О000000000000005$еѕѕіоп:29езап150000000 

redis> SET session:29e3d иіа1314 

OK 

redis> EXPIRE session:29e3d 900 

(integer) 1 

ЕХР1КЕППППШШШПППППППОППППППППППШПШШПП 

redis> DEL session:29e3d 

(integer) 1 

redis> EXPIRE session:29e3d 900 

(integer) 0 

ООООО000000000000000000007 "СОДОДОДО0000000000000 

redis> SET foo bar 

OK 

redis> EXPIRE foo 20 

(integer) 1 


redis> TTL foo 

(integer) 15 

redis> TTL foo 

(integer) 7 

redis> TTL foo 

(integer) -2 

DIEIBOaadadadfeernn a m aaaau2 eufeennbumiaaa rr T EI 
000-20 

обедобобобдоббобобдобабдобабобобабоббоббобобобводово 
ВАТ 

redis> SET persistKey value 

OK 

redis> TTL persistKey 

0000 02.60000000000000000000000- 10002.8000000000 
000-20-100000 

(integer) -1 

ОООО0000000000000000000000000ОРЕВ515ТТОДООО000000 
ОООО0002000009000000000000000000 

redis> SET Тоо bar 

OK 

redis> EXPIRE foo 20 

(integer) 1 

redis> PERSIST foo 

(integer) 1 

redis> TTL foo 

(integer) -1 


00 


00 


ООРЕВ515ТОДОДООО05ЕТОСЕТ5ЕТОООООДОДОДООО0000000 


redis> ЕХРІВЕ їоо 20 

(integer) 1 

redis> SET Тоо bar 

OK 

redis> TTL foo 

(integer) -1 
ООЕХРІВЕОООООООООО00Д00000000 
redis> SET Тоо bar 

OK 

redis> EXPIRE foo 20 

(integer) 1 

redis> TTL foo 

(integer) 15 

redis> EXPIRE foo 20 

(integer) 1 

redis> TTL foo 

(integer) 17 
ОООООООООООООООМСАОСРОБНОНБЕТОДКЕМООООООООООО 


ЕХРІКЕП Пзесопав IILI 


000000 РЕХРКЕДПОРЕХРКЕППЦО ЕХРІКЕОДОООДООООДО000000 
PEXPIRE key 1000 П EXPIRE key 1 ПОООООООО РТТЕПО0000000 
00000000 


ПП 0000 М/АТСНООООООООО000000000000000000000 


МАТСНОООООООООО 


ПИПППППОПИППИПППЕХРІКЕАТПРЕХРІКЕАТТ 

ЕХРІВЕАТПОПЕХРІВЕОДОДОДОДОДО У піхооОПОДО0000000000 
ОПОРЕХРІВЕАТОДОЕХРІВЕАТОООООДОООДО0О000000000 

redis> SET Тоо bar 

OK 

redis> EXPIREAT foo 1351858600 

(integer) 1 

redis> TTL foo 

(integer) 142 

redis> PEXPIREAT foo 1351858700000 

(integer) 1 


4.2.2 [IILI IILI 


ООООО0000000000000000000000001РООООООДОО0О00000000 
ПОООООБОВЕХРИВЕЦОП 
0000000000000000001990000000000000060000 
гасе Ига то: ПО ПРОООООООДО000000000 ІМСАОО0000000000000 
О001 0000000000000000000000001000000000000000000000 
ОО000001900р0000000000000000000000000000000000000000 
ООООбО00000000000000000000000000000 
ОД000000000 
$isKeyExists = EXISTS rate.limiting:$IP 
if $isKeyExists is 1 
$times = INCR rate.limiting:$IP 
if $times > 100 
print ОДОДОДОД00000000 


exit 
else 
INCR rate.limiting:$IP 
EXPIRE $keyName, 60 
ОООООД000000000000000000000000000000000000000000 
ООО000000000000000000001РО000000000000000000010000 
ООО0000000000 
ОООО0000000000000000000000000000000000000000 
$isKeyExists = EXISTS rate.limiting:$IP 
if $isKeyExists is 1 
$times = INCR rate.limiting:$IP 
if $times > 100 
print ОДОДОДОД00000000 
exit 
else 
MULTI 
INCR rate. limiting: $IP 
EXPIRE $keyName, 60 
EXEC 


4.2.3 ПШШШ 


00004. 2.2000000000000000000000000000000000000000 
ОДД000009000000000000000200000000000000000000000000 
00000020000019000000000000000001:9000000000000000000 
О000000000000000000000000000000000000002100000000000 
О00000000000000000000000000000000100000000000000000 


ПП 10 0000000000000000000000 10000000000000100000000 
00190000000000000000000000000000000 
ПОООООВОНОВ 
$listLength = ШЕМ rate.limiting:$IP 
if $listLength < 10 
LPUSH rate.limiting:$IP, now() 
else 
$time = LINDEX rate.limiting:$IP, -1 
if now() - $time < 60 
print ОДОДОДОД000000000 
else 
LPUSH rate.limiting:$IP, now() 
LTRIM rate.limiting:$IP, 0, 9 
000 пом()000000000 Unix 00000000000000000000000“АО 
О000080700007 В"ООООД000000000000000000000000000000 
ОООО000000000000000000000000000000006000000 


4.2.4 ППП 


ОООД000000000000000000000000СРООІОБОДОООС00000000 
ООООДО000000000000000000000000000000000000000000000 
ОДОДО010000000000000Д00000000000000000 Redis 010000000 
ОДООДО0000000000000000000000000000000000000000000000 
ООООДО000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000 

$rank = СЕТ cache:rank 

if not $rank 


$rank = 000... 
MUITI 
SET cache:rank, $rank 
EXPIRE cache:rank, 7200 
EXEC 
LLLIILILILILILILILILIUL IILI ILLILILLILLILILLILLILILLILILLILLILILIL LIU IILI] 
ОДО000 Redis ПОПОПОПОПОВОВООП Redis EB 
ООООДО000000000000000000000000000000000000000000000 
00000 Redis ДОДОДОДО0000Кеаїб tmn imi a Ord 
КеаіѕДо0000000000 
О000000000000000тахтетогубу000Кеаіѕ 000000000000 
О000000000000Кеаіѕ$000тахтетогу-ро!ісубо000000000000 
О00Кеаіѕ$П00000000000 
тахтетогу-ро1ісу00000004-1000000.&0ОПіеаѕї 
Recently Озеа оо 000000” О00000000000000000000000000 


ООО000000000000000 
04-1 Redis ОДОД00000 
я ш ж ЫЯ 
C Vvolatilecl u 00 LRU РАНО САОНА ЭЧИ АВ) 
allkeys-lru EH LRU FORMER КЕ 
volatile-random БЕН 6 (H GF ae ЛЯВА) > 
allkeys-random BE BL ER — 7 BE 
volatile-ttl ШЕЛЕГІН ет А) — 1-86 
noeviction ADR BE, RGR BR 


ООипахтетогу-ройсуПППаЙКеу$-гиПППОВеа!1 000000000 
008е91$000000000000000000-(27_00000000000000 


4.300 


ОДООДО0О000000000000000000000000000000000000000000 
ОДО000000000000----ООПОДОООД0000000000 

DOUBDBIBD 00007 00000000" 000000000700000000000000 

"ОДОО0000000059000000000000000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
ОБМЕМВЕВ5ОДОООООДОО0О00О00О0000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
000000 

00000000000 SORT 000000000000000000000 


4.3.1 [I IILI 


ОДОО00000000000000000000000000000000веаї6000000 
Кей ПОООДОДОДООДОД0О0О00О00О000000000000000000000000 
ОПООБОВОООКеа 5 ророрродрброрбороророрвеаїв о n dn Bad b d 
00000008 

ОООО0000000000000000000000000000000000000000000 
Redis ОООООО0000000000000000000000000000000000000000 
О00000000000000041ІМТЕАЅТОКЕЦ2А0МОМЅТОАЕПОО00 
ZINTER[JZUNIONII[ [J 

О000000000000000000000000000000000000Аеаіѕ 00000 
ПППППГПП MULTI, ZINTERSTORE, ZRANGE, DELO ЕХЕСП5П00 
ПОПО4!МТЕКЦ 

MULTI 

ZINTERSTORE tempkKey ... 

ZRANGE tempkKey ... 

DEL tempKey 


EXEC 


4.3.2 БОВЕ |] 


О0000000000000000 Redis 000 5ОКТОПОПОПОПОПО5ОКТОО 
ОДОООООО000000000000000000000000000000000000000000 
ООО00000"гибу"00000010000727076"0"71270726"0000000 


000000000000000$МЕМВЕВ$000000000000-87_000000000000 
ООО0О00000000000000000000000000000000000000100000 
0000000$9^АТ00000000000 

redis> SORT tag:ruby:posts 

1) "2" 

2) "6" 

3) "12" 

4) "26" 

ОООО00000000000508Т О000000000000000000000 

redis> LPUSH mylist 426137 

(integer) 6 

redis> SORT mylist 

1) "1" 

2) "2" 

3) "3" 

4) "4" 

5) "6" 

6) 77" 

ОДОООО0000000000000000000000000000000 

redis> ZADD myzset 50 2 40 3 201605 


(integer) 4 

redis> SORT myzset 

1) "1" 

2) "2" 

3)t3* 

4) "5" 

ПООООООВО0$ ОВТОПОВОПВАЕРНАОИОО000000000000000006 
00 

redis> LPUSH mylistalpha a c e d B СА 

(integer) 7 

redis> SORT mylistalpha 

(error) ERR One or more scores can't be converted into 
double 

redis> SORT mylistalpha ALPHA 

1) "A" 

2) "В" 

3) "С" 

4) "а" 

Б)" 

6) "а" 

7) "е" 

ООО000000000000АЕРНАОрО00050АТОО0000000000000000 
ОООО00000000000000 

обобобобзокт О0000000000000000000000000000000000 
ООО00000000000000050&ТрО00рЕ5СО00000000000000000000 

redis> SORT tag:ruby:posts DESC 

1) "26" 


2) "12" 

3) 6" 

4) "2" 

Обообооббобоббоборобъоктабоабеми обобобоббобовово 
SQL UUUUULIMIT offset сочп ДОППП offset прододобосомпї0 
ПП 

УОКТОООООООООООООООО 

redis> SORT tag:ruby:posts DESC LIMIT 1 2 

1) "12" 

2) "6" 


4.3.3 ВМП 


ообобоббоббобоббабобоббовбоббобогаз ааабоббобоббдодо 
поббобобейвзобаообобоббадодобббободеа обоббооббобободо 
003.6ПО00000000000000000109000000000000000000000000010 
000000000000000000000004. 3. 20000000190000000000000 

ОДОДОДОДОО0Д0О00000000006 " е 00000000000000000000 
ІР “271167114129 2 ӨӘӨІІІГІІ І8теП 000000“ 1352619200") 
“1352619600"[]“1352620100"[]“1352620000”"QUnixQQ00000 
О0000000000000000712707267076"072"ПО0000000000000 
5 ОК ООООБОБОБООВУО 

ВУООДОДО0ВУОООООООДООООДОООООДОООООО000О000000000000- 
> О000000000 BY 000508 1000000000000000000000000000 
ОООО000000000079 00000000000000000000000 

redis> SORT tag:ruby:posts BY post:*->time DESC 

1) "12" 


2) "26" 

3) "6" 

4) "2" 

ППОБ5ОКТ ДООППРрозе: 2[Jpost:6[jpost:12[Jpost: 260000000 
иглейОООПООПОЕад :гчбу:розе 5 000000100000 

ообобббоббобббобббдовобово 

redis> LPUSH sortbylist 2 1 3 

(integer) 3 

redis> SET itemscore:1 50 

OK 

redis> SET itemscore:2 100 

OK 

redis> SET itemscore:3 -10 

OK 

redis> SORT sortbylist BY itemscore:* DESC 

1) "2" 

2) "1" 

сысы 

ОО00000079 000000000000000050АТ 0000000000000 


Кей ПОООДОДОО000000000000000000000 
redis> SORT sortbylist BY anytext 


1) "3" 

Дер 

32 

000 anytext ПООООООО anytext ПООООООООО SORT 0000 
-КАМСЕОООО000000000000000000000050АТО0О000000000000 
004.3.40000000000000 


ОООО000000000000 SORT ПОООООО0О0О000000000000000 

redis> LPUSH sortbylist 4 

(integer) 4 

redis> SET itemscore:4 50 

OK 

redis> SORT sortbylist BY itemscore:* DESC 

1) "2" 

2) "4" 

3) іш 

4) "3" 

П0000"4"О0000етѕсоге:400000"1"0000іёетѕсоге: 10000 
ЗОПОД5ОТ000000747071"0000000000000000 

0000000000000000000000090 

redis> LPUSH sortbylist 5 

(integer) 5 

redis> SORT sortbylist BY itemscore:* DESC 

172727 

2) "4" 

3) "1" 

4) "5" 

5) "3" 

00075"0007 3"000000075"0000000000000 000"3"000000 
-10П 

0006 00000000000000**"000* -> "ОО00000000000000*->” 
ОДООДО000000000000000000000000000000000000000000000 
0000000 

redis> SORT sortbylist ВУ somekey->somefield:* 


1) "1" 

2) "2" 

3) "3" 

4) "4" 

2/55 

0000000000000000 SORT 00000000000000000000800000 
0000000000000000 Reais 00000000000000000000000090000 
"ПО somekey->somefield:*700"*” 000000000000000008е5 
00000000005отлекеу00 зоттейе!ч:*000“*"0000000000000000 
00000000000000008е9150000000000000 


4.3.4 СЕТ 


Ообобоббобббободоббоббовбобрбобо ID ООО000000000000 
012000Н©ЕТ0000000000000000000000000000000000000000 
00000000000000000000$9АТОООСЕТОПО 

СЕТОПОВОВОВОВОВОО 5О8ТОООО000000000000000С:27000 
ООО0006ЕТООООООВҮПОО00СЕТООО000000000000000000** 00 
ООООО00000000001900000000000000 

redis> SORT tag:ruby:posts ВУ post:*->time DESC GET 
post:*->title 

1) "Windows 8 app designs" 

2) "RethinkDB - An open-source distributed database 
built with love" 

3) "Uses for CURL" 

4) "The Nature of Ruby" 


О005ОАТОПОО00006ЕТОО00ВҮрО0000000000000000 


redis> SORT tag:ruby:posts BY post:*->time DESC GET 
post:*->title GET post:*->time 

1) "Windows 8 app designs" 

2) "1352620100" 

4) "1352620000" 

3) "RethinkDB - An open-source distributed database 
built with love" 

4) "1352620000" 

5) "Uses for CURL" 

6) "1352619600" 

7) "The Nature of Ruby" 

8) "1352619200" 

ОООМОС ЕТОДООООООО0О0000МОООООООО0000000000010 000 


0000000 СЕТ #000000 
redis> SORT tag:ruby:posts BY post:*->time DESC GET 


post:*->title GET post:*->time GET # 

1) "Windows 8 app designs" 

2) "1352620100" 

3) "12" 

4) "RethinkDB - An open-source distributed database 
built with love" 

5) "1352620000" 

6) "26" 

7) "Uses for cURL" 

8) "1352619600" 

9) "6" 

10) "The Nature of Ruby" 


11) "1352619200" 
12) "2" 
ПООООСЕТ s pnm 


4.3.5 БТОВЕ | | 


ОПООО05О8ТО00О00000000000000000000005 ТО RETTULIT 
00005оге.гези ППП 

redis> SORT tag:ruby:posts ВУ post:*->time DESC GET 
post:*->title GET post:*->time GET # STORE sort.result 

(integer) 12 

redis> LRANGE sort.result 0 -1 

1) "Windows 8 app designs" 

2) "1352620100" 

3) "12" 

4) "RethinkDB - An open-source distributed database 
built with love" 

5) "1352620000" 

6) "26" 

7) "Uses for CURL" 

8) "1352619600" 

9) "6" 

10) "The Nature of Ruby" 

11) "1352619200" 

12) "2" 

00000000000000000000000000000$ТОКЕППО$ОКТОПООЙВ 
0000000 


ЗТОКЕПОООООДДЕХРІВЕООДООООДОДОДОДОООО 
Я ПОДД00000000000 
$isCacheExists = EXISTS cache.sort 
if $isCacheExists is 1 
Я 1100000068 
return LRANGE cache.sort, 0, -1 
else 
# 000000000 5О8ТОДО00000000 cache.sortQQ0000 
$sortResult = SORT some.list STORE cache.sort 
# 0000000000 1900 
EXPIRE cache.sort, 600 
Я 000000 
return $sortResult 


4.3.6 ПП 


5ОКТОВеа!$1000000000000000000000000000$9ВТОППО 
ОООПОО(п+ mleg (iQ) min nm pd n ng anm ad and Da p amr 
ОПООООООпООВО05ОКТООООБОПОБОООК е дб00О00000000п. 2 
ОДОООО000000000000000000000000000000000000000000000 

ОДД00005О8ТО00000000000 

О1000000000000000000М3000000 

02000 4 МІТОООО00000000М000000 

ОЗО0000000000000000005ТОКЕПОО00000 


4.4 ШІП 


ОДООО0000000000000000000000000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
ООО000000000000000000000000070000000000855000000000 
00000“ 

ООД0000000"000000000000000000000000000855000000" 

ОДООО0О000000000000000000000000000000000000000000 
000 Redis ООДОДОООД000000000000000000000000000000000 
ОДООО00000000000000 

0000000000000000000000000000000000000000000000 

000000000000000000000000000000000000000000000000 
0000000000000000000000000000000000000000000000000 
ПО0000000000002000000000000010000000000000000000000 
ОДОДООО0000000000000000000000000000000000000000000 
UO" О0000000000000000000000000000" 000000 

ОДООД0000000000000000000000000000000 


4.4.1 ПП 


ОДООООО000Д000000000000000000000000000000000000000 
ОДОДООО0000000000000000000000000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
ОДОДООО000000000000000000000000 

ОДООД000000000000000000000007 00000007 00000000000 
О000000000000ргоаисегО00000000сопѕитег00000000000 
ОДООООО000000000000000000000000000 

ОДООО0000000000000000000000000000000000000000000 
ОДООООД000000000000000000000000000000000000000000000 


ОДООО0000000000000000000000000000 
00000000000 
10000 
ОДООО0О000000000000000000000000000000000000000000 
ОДОО00000000000 
200000 
ОДОООО0000000000000000000004-20000000000000000000 
00 


ЕЯ 





04-1 ОООПОДОО0000000000 


4.4.2 | Кея в ПП 


ОПОПОБОБОООКее 0000003.4.2000000 С РОБНОКРОРООООО 
0000000000000000000000000004Р9$Н000000000000000000 
ОПООВРОРОДООДОДОО000000 

ОООО00000000000000000000000000000000000000003000 
ОДООДО000000000000000000000000000000000000000000000 

+ ООООД000000000 

loop 


$task = RPOR queue 
if $task 
Я ДОДОО000000000 
execute($task) 
else 
Я 0000000 1 000000000000 
wait 1 second 
000000 Redis ОООООООДО0О0000000000000000000000000 
ПО000000000000 RPOP П000000000000000000000000000000 
0000000006000 ВАРОР 0000000000000 
ВАРОРППОАРОРБО000000000000000000ВКРОРЦО0000000 
ООО000000000000000000 
loop 
Я ПОООООСООООООВВРОР 000000000000 ехесите()П 
$task = BRPOP queue, 0 
Я ПОДОДОбОО00000000000000000000000 
execute($task[1]) 
ВЕРОРООООДОООДООО0О0О0000000000000000000000000000 
0000000000 npn md" 9"000000000000000000000000000 
000000 
00000000 BRPOP П000000000000000000000 ВВРОРППППП 
ПО0000геаіѕ-сіі000000А00 
геаіѕ А> ВАРОР queue 0 
ПО0000010000000000000Вврбачеиепо000000 
геаіѕ B> LPUSH queue task 
(integer) 1 
ЦРИ5НЦППЦППШШПАПППШШЦППШП 


1) "queue" 

2) "task" 

О0О0ачечеП npn ii 

redis» LLEN queue 

(integer) O 

ПП ВКРОРОПОПВеа!$ ПППП ВЕРОРПД ВЕРОРООДОДОДОДОДО 
ВЕРОРОПППООИВИВОВОВЕРОРИНОВОВОПОЙ 


4.4.3 ППППП 


А О О О О IILI] 
ОДООДО0000000000000000000000000000000000000000000000 
001000р0000000000000000000000001000000000000000000 
000000190000000199900000003000000000000000000000000 
ОДООДО0000000000000000000000000000000000000000000000 
ОПО001000б0000000000000000000000З0000000000000000000 
ОДООДО000000000000000000000000000000000000000000000 
ООООД00000000000000 

ОООО00000000000000000000000000000000000000000000 
ОДО0000000000000 

BRPOP ОПОДОДОДОДОДОДОДООООО BLPOP key [key ...] 
timeout[|[] BLPOP queue:1 queue:2 ОПППППППППППППППППППП 
обобободобдобобобобобобобОббббободо redis-cli ППППППАПП 

redis А> BLPOP queue:1 queue:2 queue:3 0 

000800 

redis B> LPUSH queue:2 task 

(integer) 1 


ООДАООО00 

1) "queue:2" 

2) "task" 

ООО00000000000000000000000000000000ачеие:2р 
queue: 3000000000 

redis> LPUSH queue:2 task1 

1) (integer) 1 

redis> LPUSH queue:3 task2 

2) (integer) 1 

ОПООВКРОРООО 

redis> ВКРОР queue:1 queue:2 queue:3 0 

1) "queue:2" 

2) "task1" 

0000000000000000000000000 queue:confirmation. email 
Пачеџе:посаНоп.еглан О00000000000000000000000000000 
00000 

loop 

$task = 

BRPOP queue:confirmation.email, 
queue:notification.email, 
0 

execute($task[1]) 

ОДОДОДОДОО0000000 queuve:confirmation.email ПППППП 
queue: notification.email ОПОДОДОДОДОДОДОООООО000000 


4.4.4 " i 


ОО00000000Аеаіѕ ООООД0О0О00000000700/00" 
Hpublish/subscribeQQ00" 00/00" 0000000000000000000000000 

“ООЛО” О00000000000000000000000000000000000 
Псһаппе[0000000000000000000000000000000000000 

ПОООООООООО PUBLISHQQUD PUBLISH channel message[][] 
Пспаппе. 1 ПАР П 

redis» PUBLISH channel.1 hi 

(integer) O 

Обооообоббровизън ОДОООООДООО0О0О00000000000000000 
ОООсћатпе!. 1Д000000000000000000000000000000сбапплеї. 10 
ООООб0000000000000000000000 

00000000 ЅОВ5САІВЕПОО000000000000 SUBSCRIBE 
channel [channel ...10000000геаіѕ-сіі ПП АПОПОПО channel.1[] 

redis A> SUBSCRIBE channel.1 

Reading messages... (press Ctrl-C to quit) 

1) "subscribe" 

2) "сћаппе!.1" 

3) (integer) 1 

00 SUBSCRIBE [1000000000000000000000000000 
SUBSCRIBE[JUNSUBSCRIBE[]PSUBSCRIBE[]PUNSUBSCRIBE[]A[] 
ПО“ 00/00" О000000000000300000000000000000 

00000000000000300000000000000000 3 000000000000 
ПОО0000000000000000000000000000000000300 

0105иоѕсгіреро00000000000000000000000000000000000 
ОД0000000 

П20теѕѕадер00000000000000000000000000000000000 
ОДО0000000000000 


ОЗрипѕирѕсгібеП000000000000000000000000000000000 
ООООО000000000000000000000000000000000700/007"0000000 

ОООД00А000спаппеї 100000000000О5иб5сгіоеррро00000 
000000геаїз-сії )08О000спаппеї 10000000 

redis B> PUBLISH channel.1 Ні! 

(integer) 1 

ППППШШПШПШПИПППЦПсһаппе!.1ПППППАППШШШте55адеПППП 

1) "message" 

2) "сћаппе!.1" 

3) "hi!" 

ПП UNSUBSCRIBE ППППППППППППППППП UNSUBSCRIBE 
[channel [channel ...11000000000000000000 > П 


4.4.5 [ШШШ 


О000005985 САІВЕДПОООООДОООДООДООДОР5УВУСВІВЕООГО 
ОДО000000091060000000003.1000000000000геаїз-с и ПОСПОО 


ПП 
redis С> PSUBSCRIBE channel.?* 


Reading messages... (press Ctrl-C to quit) 

1) "psubscribe" 

2) "channel.?*" 

3) (integer) 1 

ППспаппе!.?#  ППспаппе!.1 Пспаппе!. 10000000сћаппе!. 
ОД0008000000 

redis B> PUBLISH channel.1 hi! 

(integer) 2 


О0000200000А000СО00000000сһаппе!.100000С00000000 

1) "ртеѕѕаде" 

2) "channel.?*" 

3) "channel.1" 

4) "hi!" 

ООО0000000000Р50ОВ5САІВЕВПО000000000000000000000 
ООООДО000000000000000000000000000 

ПО ПОРБОВ5ССВІВЕДПООООДООООПООООООО0ООПР5УВУСВІВЕ 
channel.? сһаппе!.?*0000 channel.2 О0000000000000000000 
РОВСТУНООО0О00002000100000000000000000 SUBSCRIBE 
channel.10[]PSUBSCRIBE сћаппе!. 2 П00сћаппе!. 1000000000 
ОО000000000000000О пез5адеПртеззадедрПДПРОУВІТ5НОО000 
20 

PUNSUBSCRIBE 000000000000000 PUNSUBSCRIBE 
[pattern [pattern ... ] ПОООООДО000000000 

ПО ОПРУМ5ОВ5СВІВЕПОООДОСО РУВУ5СВІВЕПДОДООДОДООО 
00000 SUBSCRIBE ОДООО00000 UNSUBSCRIBE 000000000 
РУЦВУСК!ВЕОООПООООООПОВОБООПООРОМЗЦВУСКВЕОООООООО 
ООО0000000000000000000000000РОМ50В5СКІВЕ "0000 
спаппе! ЖПППППИПИП PUNSUBSCRIBE channel.*Q 0000 


4.5 ||| 


Дрр0веаї  0ТЄРЮДОДООО000000Веаї род000Веаї рр 0000 
ОДООООО000000000000000000000000000000000000000000000 
О00000000001оор back адагез5 ПОПОПОПОПООПОП Redis 00000 


О0000 LPUSH list 1 2 ЗОПОООО00000000000000000000000000 
00000000 

ОООО0000000000000000000000000В8еаїбоб00000000000 
О000000000000000000роѕ:1Проѕё:2Проѕё:ЗОЗО000&еро000 
0030000000004-2000 

Redis ОДДОО00000Орі реїіпіпд ПП ПВ 
ОДООООО000000000000000000000000000000000000000000000 
ОДОД00000000000 Redis ОДОДОООООО0О000000000004-3000 

О5ООД0000000000000000000000000 


HGET post:1 title 


“S— RAB” 
HGET post:2 title 
“BRAS” 
HGET post:3 title 
“Ж= БНБ” 
ЖЕРІ Redisig 5 25 


04-2 ОДОООООД0О000000000000 


HGET post:1 title 


HGET post:2 title 
HGET post:3 title 
Ж-Н” 
Ж-Н” 
FIRAS 
® PR Кеаїз 55 #8 


04-3 1000000000000 


4.6 ПППП 


Jim Gray 19! rina" 0000000000000000” 000000000000000 
00002 01 200000000000000005 2 46 6 вррресго0роро000000000 
ОДООООО000000000000000000000000000000000000000000 
Redis ООДООООООДОДО0О000000000000000000000000000000000 
0000000000000 


4.6.1 ПШПШ 


ОООО0000000000000000000000мегу.і прог ап. регзоп:20П 
ОМІР:200000000000000000000000000000000000000000 
МІР:20000МУ:20000000000000000000000000000000000000000 


ДООплатер'еттатедрО0000000поЕСООДО00000000000000000000 
ОП10000000000000000 0 


4.6.2 [NNN 


ОДОДОДОО00000000000000000000000000 Redis[ ороробО0О 
0000008е91$00000000000000000000000000000000000000006 
0000000009(1)0000000000000000000000000009(1)0000000 
О(п)00000000000000008е91000000000000000000000000000 
О(п)О00000000000000000000000000000Аеаіѕ 000000000000 
ОО00000Кеаіѕ$00000000000000000000000000000000000000 
OBJECT ENCODING 000000 

redis> SET foo bar 

OK 

redis> OBJECT ENCODING foo 

"raw" 

RedisQUOU0U0000UredisObjectQQU000UredisObjectQ00000 

typedef struct redisObject { 

unsigned type:4; 
unsigned notused:2; /* Not used */ 
unsigned encoding:4; 
unsigned Iru:22; /* Iru time (relative to 
server.lruclock) */ 
int refcount; 
void *ptr; 
) robj; 
О0урероо000000000000000000000 


#define REDIS_STRING 0 

#define REDIS_LIST 1 

#define REDIS_SET 2 

#define REDIS_ZSET 3 

#define REDIS_HASH 4 

encoding ПООПООКеа 5 pin mp aad 

#деппе REDIS_ENCODING_RAW О /* Raw 
representation */ 

#define REDIS_ENCODING_INT 1 /* Encoded as integer 
*/ 

#define REDIS ENCODING HT 2 /* Encoded as hash 
table */ 

#define REDIS_ENCODING_ZIPMAP 3 /* Encoded as 
zipmap */ 

#define REDIS_ENCODING_LINKEDLIST 4 /* Encoded as 
regular linked list */ 

#define REDIS ENCODING ZIPLIST 5 /* Encoded as ziplist 
"f 

define REDIS ENCODING INTSET 6 /* Encoded as intset 
+ 

#define REDIS_ENCODING_SKIPLIST 7 /* Encoded as 
skiplist */ 

#define REDIS_ENCODING_EMBSTR 8 /* Embedded sds 
string encoding */ 

ООО0О00000000000000000 OBJECT ENCODING [0000000 
4-2000 

04-2 ОДОООДООД000000000000000 


Ж gg Ж = А5755 OBJECT ENCODING ФС В 








FIF ei REDIS ENCODING RAW "raw' 
REDIS ENCODING INT "int" 
REDIS ENCODING EMBSTR "embstr" 
HU JH REDIS ENCODING HT "hashtable" 
REDIS ENCODING ZIPLIST "ziplist" 
Еж REDIS ENCODING LINKEDLIST "linkedlist" 
REDIS ENCODING ZIPLIST "ziplist" 
Ая REDIS ENCODING HT "hashtable" 
REDIS ENCODING INTSET "intset" 
EFEC REDIS ENCODING SKIPLIST "skiplist" 
REDIS ENCODING ZIPLIST "ziplist" 
ООДО0О0000000000000000000000 
1000000 


Кеаіѕ$П000595һагғу000000000000гедіѕОЮјесре0000000 
О0000$95һаг00000 
struct ѕаѕһаг { 
int len; 
int free; 
char buf[]; 
}; 
ОЮШепорободобороро “ее 0006ч7000000006ч77100000000 
00000 
00000 SET key foobarQQU000U00000000 
sizeof(redisObject) + sizeof(sdshdr) + strlen("foobar") = 300 


0.18! 0004-4000 
00000000000640000000000кеаїз ОДОДООІіопа 0000000 

SET key 123456000000000 sizeof(redisObject) = 16 ПП 

О"Тообаг'"ОД000000000004-5000 


redisObject 


type 
(REDIS_STRING) 
encoding sdshdr 
(REDIS_ENCODING_RAW) 


04-4 ППППП foobar"[]] RAW 00000000 
redisObject 


type 
(REDIS_STRING) 


encoding 
(REDIS_ENCODING_INT) 





ptr( 123456) 





04-5 00000"123456"00000 
геаіѕОрјесПгеѓсоипєОООО0О00000000000000000000000 
Кеаіѕ000000001000000000000999900000геаіѕОрјес 00000 
О0000000000000000010000000000 SET Кеуі 1230000000000 
О000000000 redisObject ПОО00000000000000000004-6000 
О0000000000000000100000000000000000АеаіѕО000000 
00000000000 


redisObject 


type 
(REDIS_STRING) 
encoding 
(REDIS_ ENCODING. INT) 


prt(123) 





04-6 0000 SET key1 123 П SET key2 123 ППКеу1 П key2[][] 
ОДООД0Д000000000000000000000 
ПО 000000000 maxmemory 000 Redis О0000000000Кеаіѕ 
ОООД000000000000000000000 redisObject ППППЕВУПОП 


ППЕесй 3.00000 REDIS ENCODING EMBSTR ОДООДО0000 
О0000АЕЮОІЅ5 ENCODING ВАМЦ0100000595һаг000000595һаг 
00000000000000000000000004-7000 


type 
(REDIS_STRING) 
encoding 
А ‚ (REDIS_ENCODING_RAW) 


sdshdr 





buf("foobar") 


04-7 ППППП Тообаг"ПП EMBSTR 00000000 
ООВЕРІ5 ENCODING ЕМВУ5 ТЕОДОДОООООО0000000000000 
000000000000000000000000000000000000000000000000039 
OO00Redis 000 REDIS_ENCODING_EMBSTROQOO00000 
REDIS_ENCODING_EMBSTROOO0000000000000APPENDQ000 
Кеа 5 ПОООООАЕР15_ЕМСОРрМО_ВАМПОО 
200000 


00000000000000 REDIS_ENCODING_HT П 
REDIS ENCODING ZIPLIST!2! ППППППППППППП 
REDIS ENCODING 21РШЅ5ТО00000000000 

hash-max-ziplist-entries 512 

hash-max-ziplist-value 64 

ППППИПППОПОГПһавһ-тах-2іріі5і-епігіе в До n mb td d 
0000 hash-max-ziplist-value П00000000000Аеаіѕ 0000 REDIS _ 
ENCODING ZIPLIST П00000000000 REDIS ENCODING НТ ДПО 
ОО00000000000Аеаіѕ$П00000000000000000 

REDIS ENCODING НТОО0000000000(1)000000000000000 
ОПОООВОВОО redisObject ОО0000000000000000000000000000 
ОДО000000000 

ПП Кео  ДОДОДОДОДОД0000000 REDIS_ENCODING_HT ПОП 
ОО0000000000 redisObject 0000000"123456"0000"арсае'О00 
ОДООДО000000000000000000000000000000 

0000 Redis 10000000000000000000000 геаїзо 0000 
redisDbQQ0000 

typedef struct redisDb { 


dict *dict; /* The keyspace for this DB */ 
dict *expires; /* Timeout of keys with a timeout 
set */ 


dict *blocking keys; /* Keys with clients waiting for 
data (BLPOP) */ 

dict *ready keys; /* Blocked keys that received a 
PUSH */ 

dict *watched keys; /* WATCHED keys for 
MULTI/EXEC CAS */ 


int id; 

) redisDb; 

dictDnnaaaadexpiresrntnn ia uRedisrpmaa a 
аағаразез ОПОДОД000000 геаї  ОБОДОООДОДОДОДОООО 

REDIS_ENCODING_ZIPLIST О000000000000000000000000 
ООООД000000000000000000000000000000000000000000 
REDIS ENCODING ZIPLIST 000000 4-8 ППППП zlbytesr] 
uint32 #0000000000000021&аі!00 uint32 #0000000000000000 
ПП zitail 00000000000000000000000000000000000000000000 
ПИПППП епПиіп(16 #0000000000002епапооооооооооо000 
0000002550 


5 BI — T ZU SB AUN 


04-8 REDIS ENCODING ДРШИ5БТООООООО 
[JREDIS ENCODING 21РШЅ5ТО000004000000 


ОДД00000000000000000000000000000000025400000000 
О0300000000050000 





[00000000000000000000000000000000000 63000000000 
DULIZIP. STR. 0eB[jmo < <600000000060000000000000000000 
ООО0000000100000000000630000001 63 8 37 О0000000000000 
0020000000000016383000000000000000005000 

О00000000000000000000000000Аеаіѕ=0000000000000000 
О000000000000000000001п16 t[jint32 #000 

ППҺЕрІ5 ЕМСОРІМС_21РИЅТОООО00000000000000001000 
О10002000001000000004-9000 

00000000 HSET hkey foo баг0000һкеуП000000004-10000 


ЕНЕ! 


8182 


04-9 ПП REDIS ENCODING ZIPLISTQQUOQUU0UU0U00 





zibytes(21) 





04-10 hkey|[|[ DIII) 

000000 HSET hkey foo апо{ПегуаиеПВея!$ 000000000 
ғоорО000000000000000000000000000000000000000000 
апоһегуаічер0000000000000000000000000000000000000 
ПППППППППППППППИППППП һаѕћ-тах-21рііѕї-епіпеѕПћаѕћ-тах- 
ziplist-valuerJ rt npn 

300000 

О0000000000000 REDIS_ ENCODING LINKEDLIST[] REDIS 
ЕМСОРІМС 21РИЅТОО0000000000000 
REDIS ENCODING 21РШЅ5ТО0000000 

list-max-ziplist-entries 512 


list-max-ziplist-value 64 
ОДОО00000000000000000 
REDIS ENCODING ШМКЕОШЅТО0000000000000000000 
redis Object ОПООООДОДОДОДООДОДОДООО0ООДО00000000 
000 REDIS ENCODING ZIPLIST 00000000000000000000 
REDIS_ENCODING_ZIPLIST [10000000000000000000000000000 
0000000 
веаїб(П о ДОД000П00 ВЕРІ5 ENCODING ООІСКИЇЗТОДОДОООЛ 
ПППВҺЕОІ5 ENCODING LINKEDLIST[]REDIS ENCODING ZIPLIST 
О00000000000000000000000000 ггр ие ООО0000000000000 
REDIS ENCODING ZIPLISTQOOOQ00000 
400000 
0000000000000 REDIS ENCODING НТ П 
REDIS ENCODING ІМТЅЕТОО00000000000000000000000000 
ѕеі-тах-іпіѕеё-епёіеѕ0000000005°1200Аеаі5000 
REDIS ENCODING ІМТЅЕТО000000000000 
REDIS ENCODING НТПППП 
REDIS ENCODING ІМТ5ЕТОДОДОДОЇ ве 0000 
typedef struct intset í 
uint32_t encoding; 
uint32_t length; 
int8_t contents[]; 
) intset; 
ОПсоптепев ПООПООООПОПОООПепсоата 0000000000000 
ОО000епсоа та !МУТ5ЕТ Емс ІМТ16Д2000000000000000000 
2 П000000Аеаіѕ 00000 encoding ПОД INTSET_ENC_INT32004 


Оробороророродоророоорро0Оепсоаі 900000 
INTSET ЕМС INT64Q08Q0000 

REDIS ENCODING ІМТЅЕТПОО0000000000000005МЕМВЕЋЅ 
ОО00000000000000000000000000000000000000000 Redis 000 
ООО00000000000000000000000000 

О00000000000000000000005ее-тах-іпѕеё-епёгіеѕ$00000 
ППВеаі$П000000000000006ЕЮрІ5 ENCODING НП 

ПП 00000000000 REDIS_ENCODING_HT О00000000000000 
о000Аеаі 0000000000000 REDIS ENCODING ІМТ5ЕТОООООЛО 
00000000008е91$000000000000000000000000000000000000 
О0000000000000090(п)0000 

З0000000 

ООДОО0Д0000000000 REDIS ENCODING SKIPLIST [| 
REDIS ENCODING ДРШИ5БТООООООООООООООО 
REDIS ENCODING ДРШИ5ТОООООООО 

zset-max-ziplist-entries 128 

zset-max-ziplist-value 64 

ООО0000000000000000000 

ПОПОООКЕО!5 ENCODING 5 РПЗТ Кея зОДОДДОДОДЛ 
Uskip изеаоаоообообдодоббодойдоббододоббободоббобоббодо 
О(1)000000 ZSCORE [100000000000000000000000000000000 
ОКе в о рОООО00000000000000000000000000000000000000 
ПООО0О000000000000000000000 

ООДОД00000000000 redisObject ВО0000000000000000000 
оббобобоббобойбраочетедопопо 

ППЕКЕрІ5 ЕМСОВІМС_21РШЅТОО000000000000*001000001 
0000002000002000”000000000000000 





[3]. ддррдоОродорророріорррородуорородбвеаіз 0000000000000000000000004.60 





[4]. 000000000000000000000000000000п2000п20 

[5]. О0геаіѕ-сіі | UNSUBSCRIBE 

[6]. Jim Ссгау)1998000000000000000000000000000000002007 00000000000 

[7]. 3.2.4 0)000000000000000000000000000 

[8]. 00000000064 Пі іпихо)0000 

[9]. []Redis 2.4 REDIS ENCODING HT 
REDIS ENCODING ZIPMAP 
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ОДООО0000000000000000000000000000000000000000000 
ОД00000000 Redis 000000000000000000 

О00000000000000 Redis 0000000 redis-cli 0000000000000 
Д0000кеаїддДрОДООВеОООДО00Веаї 5 ПРНРОРу поп КчБуП 
Node.js ПОПОООО0О000000000000000000000000000000000000 


5.1 PHP/|Redis 


Кей  ПООДОРНРООООРГеаіз E Прһргеаіѕ 121 ППППППППРНРП 
О0000000000000000С00000РНРО000000000000000000000000 
ООООООООБОООООООРН РООООООБОБОР геа в ПОПОООПОРНРОВО 
Redis[] 

OOPredisQU0UUphpredisQU0000000RedisQO0000000000000 
ПППППППИП Redis 100000000000000000000000000000000000 
000000000000000000000 

РгейїзПРНРПППППППП5.3П 


5.1.1 ПП 


ПП Predis 00000000091 clone git://github.com/nrk/predis. 
УЇКОДООДОО061ЕНеБО00000000021Р0000000000м1.0.12000000 


https://github.com/nrk/predis/archive/v1.0.1.zip[| LLL LU] 
ОДО000000000000 

ПО0000000ачќёоіоаа.рпроб000000000 ргеаіѕ ВО00000000 
0000 

require './predis/autoload.php'; 

Predis ОДОРНР 5.3 000000000000?58-0 00 33! 0 
autoload.php О00000РНРО000000000000000000ачќоіоаа.рпр 
ООООДО000000000000000000000000000 

$redis = new Predis\Client(); 

ОДОДОРГеаїв ПОДОСТІепі. рпРрОДОДОДОДОООПОРНРОДООООДОДО 
ПО00000000ачќѓоіоаа.рһрд0 


5.1.2 ІП 


ОПОПОООКее 0000 
$redis = new Predis\Client(); 
ОПОПОООКее 8 000127.0.0.1000063 79П000000000000000 
ПП 
$redis = new Predis\Client(array( 
'scheme' => 'tcp', 
'host' => '127.0.0.1', 
'port' => 6379, 
)); 
ОО000000000Овеє 000000 
echo $redis->get('foo'); 
0000000000 foo О00000000000000000000000ҹоЦр 
Оғоо00000000000000000000000000000000000000 


try í 
echo $redis->get('foo'); 
} catch (Exception $e) { 
echo "Message: {$e->getMessage()}"; 
} 
000000000“ Message: ERR Operation against a key 
holding the wrong kind of value"[] 
0000000000 ЗЕТОДОДОДОГО LPUSH numbers 1 2 30 
$redis->Ipush('numbers', "1", 2", '3'); 


5.1.3 ПППП 


ОДОДОДОДОРГеаїв 1000000000000000000000000000000 
Ргедї  ООПМ5ЕТОДООДООРНРОДОДОДОДОДОДОДОДО 
LOMGET/MSET 
$userName = аггау( 
'изег:1:пате' => "Тот", 
'user:2:name' => 'Јаск' 
); 
//JOU$redis->mset('user:1:name', Чот", 'user:2:name', 
Jack); 
$redis->mset($userName); 
ПОМСЕТОДОДОДООДОДОПО 
$users = array keys($userName); 
print_r($redis->mget($users)); 
LLL IILI] 
Array 


( 

[0] => Tom 

[1] => Jack 
) 
21НМ5ЕТ/НМСЕТ/НСЕТАЦ. 
Ргед 8 ПІНМ5ЕТПОДОМ5ЕТОООЙО 
$userl = array( 

"пате" => Тот", 

‘age’ => '32' 
) 
$redis->hmset(‘user:1', $user1); 
НМСЕТОМСЕТОПООПООООООООНСЕТАЕЕО ОО Ргеа1 ПКея5 

ОДО00000000000 

$user = $redis->hgetall('user:1'); 
echo $user['name']; // Тот! 
30LPUSH/SADD/ZADD 
ГРУУНО5АРООДО000000 
$items = аггау('а', 'b'); 
//O00$redis->lpush(‘list', "а", 'b'); 
$redis->lpush(‘list', $items); 
//00$redis->sadd('set', а", 'b'); 
$redis->sadd('set', $items); 
ОФАРОДООО0О0 
$itemScore = array( 

Тот" => '100', 

Маск => '89' 
); 


//QO0$redis->zadd('zset', 1100", Тот", '89', 'Јаск'); 
$redis->zadd(‘zset', $itemScore); 
ДП5ОВТ 
ОРгеаіѕ$П0050КТООООО0000000000050АТПО000000000000 
0000000000000 SORT mylist BY weight * LIMIT 0 10 
GETvalue * GET Я ASC ALPHA STORE геѕиЦ0000000Ргеаіѕ 
ООБОБОВО 
$redis->sort('mylist', аггау( 
'by' => 'weight *', 
limit" => array(0, 10), 
'get' => array('value *', '#'), 
'Sort' => "азс", 
'alpha' => true, 
'store' => 'result' 


5.1.4 ПШ 


О0000РНРОАеаіѕ000000000000000000000000000 

1000 

ОДООО0000000000000000000000000000000000000000000 
0000000000000 

ООДОД0000000000000007 user: DEI" 0ОДОДІЗООО000000000 
000 10 ОООО00000000000000000000000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
ОДОД00000000000000000000000000000000 email.to.id 00000 
ОДОТФОООД0Д000000000000000000100 


ОООООООООО0000000000000000000000000геоіѕёег.рпро00 
ОДО00000000000000000 

/ІПП Content-type 100000000000000000000 
ИООПОБОВОБОВОВОВОВБОВОВ че 80 
header("Content-type: text/html; charset=utf-8"); 
if(l'isset($ POST['email']) || 

lisset($ POST['password']) || 

lisset($ POST['nickname'])) 1 

echo "ПОО0000007; 


exit; 
} 
$email = 5 POST['email']; 
ИОДОО0000000000 


if(!filter var($email, FILTER VALIDATE EMAIL)) í 
echo '0000000000000" 

exit; 
} 
$rawPassword = $ POST['password']; 
ИПЕВОВОВОВООО6О 
if(strlen($rawPassword) < 6) { 

echo "ПООООДО00000000 err; 

exit; 
} 
$nickname = $ POST['nickname']; 
ИОООООО000000000000000000000000000 
ИОООООО0000000000000000 
$redis = new Predis\Client(); 


if($redis->hexists('email.to.id', $email)) 4 

echo 'QOQU0000000': 
exit; 

} 

000000000000000000 Redis В00000000000000000000000 
ОДООДО000000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 
ОДООб000000000000000000 

ОООООО000000000000000000000000000000000000000000 
ПОБООО00“0”0$а!00000000000000000000000000 Berypt 0000 
ООООООЦРНР 5.3 0000 сгурПППВсгур | оДрборородбо0000000 
ПО0сгурєО000000000 

function bcryptHash($rawPassword, $round = 8) 

{ 

if ($round < 4 || $round > 31) $round = 8; 

$salt = '$2a$' . str_pad($round, 2, '0', STR PAD LEFT) . 
$ 

$randomValue = openssl random pseudo bytes(16); 

$salt .= substr(strtr(base64 encode($randomValue), 
'+', '.'), 0, 22); 

return crypt($rawPassword, $salt); 

} 

ПП ореп$$|_гап4от_рзеиао_Буе$ПППОППОрептп$5ЕППП 

ОДО00000000000000 

$hashedPassword = bcryptHash($rawPassword); 

ООО0000000000000000300000000000 

require './predis/autoload.php'; 


$redis = new Predis\Client(); 


ИОООО0000000 ID 
$userlD = $redis->incr('users:count'); 


IT ODD] 
$redis->hmset("user:{$userlD}", array( 
'email' => $email, 


‘password' => $hashedPassword, 
‘nickname’ => $nickname 
)); 
/ГППИПШШПШПП ID 00000 
$redis->hset('email.to.id', $email, $userlD); 
ИОО000000 
echo ПОП; 
ОДОООДО000000000000000000000000000000000000000000 
00000 
2000 
ООООО0000000000000000000000007000070000070000000 
ПО 
ОДо000000000000Петпаїї.єо 'АПОДОДІФОДООД0О0000000000 
DEBEO Og p ndn d dg ag dd dd dad dm a d] ad p] dn d d dte gi n. ph p 000 


LLLILILILILIUL IILI IILI I UI I 
header("Content-type: text/html; charset-utf-8"); 


if('isset($ POST['email']) || 
lisset($ POST['password'])) 4 
echo 'QQ0000000': 
exit; 


} 


$email = $ POST['email']; 
$rawPassword = $ POST['password']; 
require './predis/autoload.php'; 
$redis = new Predis\Client(); 
#ООООО ID 
$userlD = $redis->hget('email.to.id', $email); 
if('SuserlD) í 
echo "ПОО000000"7; 
exit; 
} 
$hashedPassword = $redis->hget("user:{$userlD}", 
‘password'); 
ОДООО00000000000000000000000000000000000000000 
осгурёНаѕћО000000000000000000000000000000сгур 0000 
ПО00сгур 0000000000000 
function bcryptVerify($rawPassword, $storedHash) 
{ 
return crypt($rawPassword, $storedHash) == 
$storedHash; 
} 
ОДО0000000000000 
if('bcryptVerify($rawPassword, $hashedPassword)) í 
echo 'ППШШПШШПП'°; 
exit; 
} 
echo ПОП); 
300000 


ПОООООоООООоОООоООоОооооооооооооооооооооооооооооо0 
ООО000000000000000000000100100000000000000000000000 
0000000 

ОДООО000000000000000000000000 

01 ОПОДО0000000004..2.З000000000000000000000000000 
ОООООО00000000000000000000000000000000000000000 

$КеуМате = "rate.limiting:{$email}"; 

$now = time(); 

if($redis->llen($keyName) < 10) 1 

$redis->lpush($keyName, $now); 

| else í 

$time = $redis->lindex($keyName, -1); 
{пом - $time < 60) í 
echo "ПОООДОД000000000;; 
exit; 
} else { 
$redis->lpush($keyName, $now); 
$redis->Itrim($keyName, 0, 9); 
} 

} 

оббодоббобебтРодобоббобббоббороддо 

П20000000000000000000000000000000000000000000000 
ООО0000000000000000000000геёгіеме.раѕѕмога.соае:00000 
ПОООООООООООООЕХРІКЕОООООООООООООО1ООООООООООО00000 
оббоббобдоббоббоббобоббобобООЪБОБООВБОБОВ сгур 0000000 
обебобабобобБОБОВО 


5.2 Ruby[]Redis 


Вед  ОООПОВчвубббйгеятв-г 12 П0000000Аеаіѕ00000000 
О0000000000000Аеаіѕ$П00000Ріеќег Noordhuis[] 


5.2.1 П 
ПП gem install геаі$0000000геаіѕ-го0000000003.2.00 


5.2.2 ПП 
уррвеаї 000000 


require 'redis' 

redis = Redis.new 

О000000Аеаі$1000127.0.0.1000063790000000000000000 
ПП 

redis = Redis.new(:host => '127.0.0.1', :port => 6379) 

гед!5-гъбоообобобдододобобобобоборе#Нчьбобободово 
обебобабобобродо 

r.set('redis db', 'great k / v storage') Я => ОК 

r.get('redis_db') # => "great k / v storage" 

r.incrby('counter', 99) # => 99 

r.hmset('hash dt', :key2, 'value2', :key3, 'value3') # => 
OK 


5.2.3 [TIT] 
гедї-"ГБПООДОО00000005ЕТОСЕТОДОООДПОДОО 


redis.set('key', 'value') 


0008 

redis['key'] = 'value' 
ПП 

value = redis.get('key') 
0008 


value = redis['key'] 
ОООО0000000000000000000000000 
redis.multi do 
redis.set('key', "Пі") 
@value = redis.get('key') 
redis.set('key', '2') 
@number = redis.incr('key') 
end 
p @value.value Я [J[]"hi" 
р @number.value # ПП 3 


5.2.4 ПИО 


ООДОДО0000000000000000000000000000000000000000000 
ООООО000000000000000000000000000000000005-1000 
start 
starter 


Startrek 


startup.ly 


05-1 ПО start’ IILI start 00000 


ОДООО0О000000000000000000000000000000000000000000 
00000000 

ПОО000ОВе 1$  ДОО000000000000000В56У0000 

ОООО00000000000000000000000000000000000Уго by "TET 
ОДО000Уг" "ru" Dru b " O00 300000000000 00000"ru by " E] 

D ruby" r"redis" (O0000RedisOO0000005-20000000"r" DULT 


000000“ prefix e" DBEID"r" BID" ruby "D^redis "D ETD 
EA Жен 


prefix:r ruby, redis 
ruby 

prefix:rub ruby 

prefix:re 


prefix:red redis 


prefix:redi 


05-2 "гибу"ДО"гедїз" 00000000000 


ОДООООО00000000000000000000000000000000000000000 
ЅОАТОПО0ВҮПО000000000000 

О0500000000000000000Аеаіѕ$0005аІуаѓоге Ѕапћ!ірро0000 

3.6ППОДООО000000000000000000000000000000000000000 
ОДОООО0000000000000000000000000 

ОЗ 00000000000000000000000000000 

О2000000000000** 0000000000000 

000000000005-3000 


ZUR TÉ 


+> 
EE 


ruby* 


05-3 "ruby" []'redis" 00000000000 
ОО000000000000000000000000000000000000000 5-3 000 
ОО000000000*г”0000000000000000000000 


O1000“r’OOOUUZRANK autocomplete rQQ000000000 

П2000 г” OOONOOOODUN=100 QUZRANGE autocomplete 1 
10101М00000000000000000000000000000000000006 

ОЗОДОДО000000000796000007г"00000000097970000000000 
0000 

ОДООД0000000000000000000000000000000000000000000 
ОДО00000000 

ОДО000000000 

00000 

00000 

006 

000 

00000 

00000 

О0000"00"00000000000 

00000 

00000 

ПО О О О 

# 100000000 

# 

# @example 

Ж get_prefixes('word') 

Я # => | ум, мо", мог, 'word*'] 

def get_prefixes(word) 

Array.new(word.length) do |1] 
if i == word.length - 1 
"# {word }*" 


else 
word[O..i] 
end 
end 
end 
р00000геаїз-годДОДОВеаї0000 
require 'redis' 
# 00000000000 Redis 000 
redis = Redis.new 
ОДОО0000000000000000000000000000000 
redis.del('autocomplete') 
О0000000000Оммо га$.6х000000000000000000000000000006 
агум = П 
File.open(‘words.txt').each_line do |word| 
get_prefixes(word.chomp).each do |prefix| 
argv << [0, prefix] 
end 
end 
redis.zadd('autocomplete', argv) 
redis-rb 0 zadd П0000000000000000000000 redis.zadd 
(key, score, member) ПОДОДОДОДООДЛО redis.zadd(key, 
[[score1,member1], [5соге2, member2], ...]) 4000000000000 
ПП 
ОДОО00000000000000000000000 
while ргейх = gets.chomp do 
result = [] 
if (rank = redis.zrank('autocomplete', prefix)) 


+ ПОООДОО0000000000 
redis.zrange('autocomplete', rank + 1, rank + 
100).each do |words| 


# 01000000 100 000 
if words[-1] == '*' && prefix == 
words[0..prefix.length - 1] 


Я ПОб е ООО00000000000000000 
result << words[O..-2] 
end 
end 
end 


# 0000 
puts result 
end 


5.3 Python[jRedis 


Ред 5 ПИПООРуУћоп0П0Огеа 5--ру 1 
5.3.1 [| 


0000 pip install redis ППППИПП геаіѕ-руро0000 
easy install[Jeasy install redis[] 


5.3.2 ІП 


000000геа1$-руП 


import redis 
00000000000000000 1 27.0.0.100063 790 «еа 5000 

r = redis.StrictRedis() 

обоббобобоббоводо 

г = redis.StrictRedis(host='127.0.0.1', рог! 6379, db=0) 
ООООБОБООПОО5ЕТОСЕТОООПОВО 

r.set('foo', Баг) # True 

r.get('foo') # 'раг' 


5.3.3 ПД 


ПИ НМ5ЕТ/НСЕТАЦ. 
НМ5ЕТООООООООООООООН СЕТА Ш10000000000000000000 
r.hmset('dict', {'name': 'Bob'}) 

people = r.hgetall('dict') 

print people # | пате": 'Bob'} 

2000000 

геаіѕ-рурО00000000 

pipe = r.pipeline() 

pipe.set('foo', Баг) 

pipe.get('foo') 

result 2 pipe.execute() 

print result # [True, 'bar'] 
обобобобобоббобобОбОбООПООегапваспоп- False[] 
pipe = r.pipeline(transaction-False) 
ОДО0000000000 


result = r.pipeline().set('foo', 'bar').get('foo').execute() 


Я [True, 'bar'] 


5.3.4 [TIT] 


О0000000000000000000000005-40000АеаіѕВО000000000 
OOU 





т TERIA (6) 


05-4 1000000000000 

ОДООООО000000000000000000000000000000000000000000 
0000000000000 ID О000000000000000000000000000000000 
ООДО00000000000 ат ТР ООООООООООД0О0000000000000000000 
ООО0000000000000000000002.000000000000000Н7 ТРО009000 
ОО0000000000000012100000000000 

ОАеаіѕ=000000010000000000000100000000000010000012 
020001202900000о00О0асіхе.иѕегѕ:20101203000120391000010 
ПППасвуе.ивегв: 3Q000000000000SADDO00000 ID 0000000000 
0000 SO О0000000000000000000000000000000000000000000 
О000000000000000000290000000000000000асіме.иѕегѕ:2 


00003000000ОПасбйїме. users: ЗДОООООД0Д0О00О00О000000000020 
000000010000 

ООООД00000000000000000000000000100000000000120000 
00000012029П00000001000000Дасібїме. изег5:2 9000000000000 
001 0бО000000000000100000000000000000000000000 
бОМОМППППП 

ОДОДООПРУЄПОПООДОДОДООООДООДме. рудООмгеб. py D 
ППРу оп 00000000000 sudo pip install web.py О0000 

ШШШПП 

# -*- coding: utf-8 -*- 

import web 

import time 

import redis 

r = redis.StrictRedis() 

"000000 

TJ: 0000000 

'Jonline':[ 100000 

urls = ( 

'/', ‘visit’, 
Чопіїпе", 'online' 

) 

app = web.application(urls, globals()) 

“""ПППППШПШППП 

пП280000000асіме.иѕегѕ:28 


def time to key(current time): 


return 'active.users:' + time.strftime('%M', 
time.localtime(current time)) 
"""ПППП 10 00000 
0000000 


def keys in last 10 minutes(): 
now = time.time() 
result = [] 
for i in range(10): 
result.append(time to key(now - i * 60)) 
return result 
Class visit: 
""" 000008 
0008 User agent 00000 10 000000000000 


def GET(self): 
user id = web.ctx.env['HTTP USER AGENT'] 
current key — time to key(time.time()) 
pipe = r.pipeline() 
pipe.sadd(current key, user id) 
# 100000000 10 ПО 
pipe.expire(current_key, 10 * 60) 
pipe.execute() 
return 'User:\t' + user id + '\r\nKey:\t' + current_key 
class online: 


Өне ДОДО0000000 


def GET(self): 
online_users = r.sunion(keys_in_last 10_minutes()) 
result = '' 
for user in online_users: 
result += 'User agent:' + user + "Пп! 
return result 
if name =="_main_": 
app.run() 
UUUUUUUUUUOUUUUUUUUUNhttp://127.0.0.1:808O0UUUUUvisit 
000000000000000000У5ег agent iji Iba ia III ser 
адепіД0000000005-5000 


eoo 127.0.0.1:8080 - и 


Овег: Мог111а/5.0 (Macin ntosh; Intel Mac OS X 10_8) AppleWebKit/536.22 (KHTML, like 
Gecko) Version/6.0 Safari/536.25 
Key: 


active. user:26 





05-5 [][]Safari [][]http://127.0.0.1:8080 
О000000000000260000000000000000000000000005-6000 


Pentadactyl 






Mozilla Firefox - 





eoo 





ы] http://127.0.0.1:8080/ 
Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:14.0) Gecko/20100101 Firefox/14.0 


User: 
Key: active.user: 


[1/1]Top 


http://127.0.0.1:8080/ [-] 


05-6 [|JFirefox[|[]http://127.0.0.1:8080 
000000029000000003700000№р://127.0.0.1:8080/опііпе 


000000000000005-7000 
Ө и — 127.0.0.1:8080/online — 2 — тə 


User agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; гу:14.0) Gecko/20100101 





Firefox/14.0.1 


05-7 00000000 
О0000000000000002900000000 
0000000000 


ОООО0000000000000000000005-8000000000000000000000 
000000190000000000000000 
Martijn Pieters less into 






website zopatista.com 
Фо location Stokke, Norway 
age 39 
member for 
t seen 
56 433 profile views 5,226 
у 


reputation 
28:65 «116 


05-8 Stack Омегом  ПОДООДОО0000000000000 

ОООО00000000000000000000000001000000000000МУпіхо 
ПОБООООЗООООООБООБОПООО2КАМСЕВУ5ЗСОКЕЦО 

ten_minutes_ago = time.time() - 10 * 60 

online users = r.zrangebyscore('last.seen', 
ten minutes ago, '+inf') 

000000000000000000000000000000000000000000000000 
О00000000000000000піпе_иѕегѕП000АеаіѕП00000000000000 
000000000000000000000000000000000000000000000000006 
ОООООООООВО Redis 1000000000000000000000000000000000 
2КАМСЕВҮЅСОКЕППОПО00000000000000000000000 

000000 ZINTERSTORE Ц ZUNIONSTORE О00000000000000 
000000000000000000000000000000000000000000000000006 


ППППППППППЦПППППППЦППППП2ВЕМААМСЕВҮ5СОВЕППППППШПШЇП 
0000000 

ОДОО0О0000000000000000000 

0100000 last.seen ПІПП temp.last.seen[ ДОП 
ZUNIONSTORE temp. last.seen 1 |а5,.љеепПИООООООООО 
ZUNIONSTORE Ообобоббобобоббобободобоббовобобоброво 
0000000 

0200000060000 10 ОПОБОБООБОВОВО 
ZREMRANGEBYSCORE temp.last.seen 0 100000 Unix[]L] 

U30UUtemp.last.seenQQU00000000000000 0000000000000 
[IHZINTERSTORE online.friends 2 temp.last.seen 
ивег:42:ТпепаеЦПЦІПІЮОПа2ППППППивег:42 ТпепаеЦІППІППІП 
000.810 

040007 КАМСЕППО0ОПопИпе Тпепаз ППП 

0500000000 %еттр Лаз1.зеепПоп те Лпепаз Петр. Јат. 
seen ОООООО000000000000000000000000000000000000000 
0000000 

ОО5000000000000000000000000 

ОООД00000000000000000000000000000000003000000 

ОДОО000000000000000000000000000000 


5.4 Node.js/|Redis 


RedisQOO00Node.jsQRedisOOO000000node redis 21 n 


ioredis_!8! ППДООООДОО000О0000000000000000000000000000 
О0000Оіогеаї00000 


5.4.1 || 
ПДпри install іогеаі00000000іогеаіѕр 
5.4.2 ||| 


LL lioredis[ 000 
var Redis = require('ioredis'); 
00000000000000000 1 27.0.0.100063 790 «еа 5000 
маг redis = new Redis(); 
ОДОО000000000000 
маг redis = new Redis(6379, '127.0.0.1'); 
00Моає )5 ООДО00000000000000000000000СЕХ267/5Е2Е7000 
00 
redis.set('foo', 'bar', function () í 
100 SET 00000000000 
#00000000 $ЕТ0000000000000000000 
redis.get('foo', function (error, fooValue) 4 
//error ПООООДОООО000О00000000000000 nu] 
РОбободобобобабобобово 
console.log(fooValue); // Баг 
|); 
ЈЕ 
О0іогеаіѕ$00000000000000сараск functienn npn nb 
0000000югеа!$000000000000000000000000000000000000006 
ОД000Оіогеаї 00ОРгопт!5е100000000000000000000000000000 
ПРготізеГ( ПП 
redis.get('foo').then(function (fooValue) í 


//fooValue ПППП 
}); 


О0№оае.јѕПО0000000000000000000000000№оаде.јѕ0800.8! 
0000000 

Мойе.) ППОПОПОО огеа ПВеч1$ 00000 Regis 0000000 
ПО000000000геаіѕ.ѕеє()О00000Аеаіѕро0000000000000000000 
О0000Моае.ј$0П0000000000000000000000000000005ЕТр0000 
ООООООЗЕ ТОООЗЕ ТООПОБОБООБООВОВОО5 E ТОООПОВОБОПСЕ ТВО 
ооебоббобободр 

МОбобобобаббоводо 

redis.set('foo', 'bar'); 

redis.get('foo', function (error, fooValue) í 

console.log(fooValue); // 'bar' 

}); 

О0005ЕТПСЕТПО0000АКеаіѕ0000000000000000000 Redis 
обобободобобобобобобоббобобобббОбСЕтоООБОБОПО“ bar] 

О0№оае .ј$000000000000000000000000000Кеаіѕ$=00000000 
ООООДО0000000000000000000000000000000000000000000000 
ООО0000000000 

redis.get('people:2:home', function (error, home) í 

redis.hget('locations', home, function (error, address) í 
redis.exists('address:' + address, function (error, 
addressExists) { 
if (addressExists) { 
console.log(‘QQ000’); 
) else í 


redis.exists('backup.address:' + address, 
function (error, backupAddress Exists) { 
if (backupAddressExists) í 
console.log(‘QU000U0)): 
) else í 
console.log(‘Q00000'): 


}); 
|), 
ОДОООО00000000000000000000000000000000000000000 
Async H9! Потер 121) ПДОПОДООДООО0ОО0О00000Азупе0000 
async.waterfall([ 
function (callback) { 
redis.get('people:2:home', callback); 
Г, 
function (home, callback) í 
redis.hget('locations', home, callback); 
}, 
function (address, callback) í 
async.parallel([ 
function (callback) { 
redis.exists('address:' + address, callback); 
), 


function (callback) í 


redis.exists('backup.address:' + address, 
callback); 
), 
1, function (err, results) { 
if (results[0]) í 
console.log(‘Q0000'); 
} else if (results[1]) { 
console.log ('O000000'°); 
} else { 
console.log(‘Q00000'): 


1000000со 122! 8050Е560бепегаёќог000іогеаіѕ00000“00 
070 
var со = require('co'); 
co(function* () 1 
var result = yield redis.get('foo'); 
return result; 
}).then(function (fooValue) 4 
console.log(fooValue); 


|); 


5.4.3 ГІТ 


LQHMSET/HGETALL 


гогеа 8 Ооо М5Е таббодобобододобобобобободоро 
НСЕТАЦ 0000000000 
2000 
О0000000 
маг multi = redis.multi(); 
multi.set('foo', 'bar'); 
multi.sadd('set', 'a'); 
mulit.exec(function (err, replies) í 
//replies ПОДООООО0О00000000000 
console.log(replies); 
}); 
обебородо 
redis.multi() 
.set('foo', 'bar') 
.sadd('set', а!) 
.exec(function (err, replies) í 
console.log(replies); 
}); 
30“00/00" 00 
Node.js QU0000000" 00/00" О0000000000000000000000 
var pub = new Redis(); 
var sub = new Redis(); 
О00ѕчюрОсһа000000000000000 
sub.subscribe('chat', function () { 
pub.publish('chat', 'hi!'); 
}); 
ОДОО00000000000000 


sub.on('message', function (channel, message) í 
console.log('[][]' + channel + '00000' + message); 

}); 

ООО0000000000 

$ node testpubsub.js 

ПОспа ООООО hi ! 

0000 О ioredis ПППППППИПИПИПИПИП redis = new Кед5 0000 
обобободобобобобобобобоббббобобобОобОБОБОбЮбюгеятер 
обедобабобобобббободово 


5.4.4 ПШР 
ООСО000000000001РО00000000000000000001Р0000000.'3 


00: 202.127.0.0 ~ 202.127.4.255 

00: 122.200.64.0 ~ 122.207.255.255 

000001Р000122.202.2.0П00000000000000000000Аеаіѕ=000 
ОДООО00000000000000 

ООДОО0ТРОДОООДО00000 

00: 3397320704 ~ 3397321983 

00: 2059943936 ~ 2060451839 

ОДООО0000000000000000000000000000000000000000000 
ОООСРООВОООО“ 6 000000000000000001Р000005-9000 


2% 


3397321983 
“ЕЖ 3397320704 
2060451839 


ACR 


“JER 2057943936 


| : | | | 


05-9 ПООООООООООООО РООООООО 

ОПООО0ІРО000000000001РО000010000000000000000000000 
ООО0000000000000** О000000000000000000000001РО00000 
ПП 

0000007 122.202.2.0"П000000000000072060059136"0000 
00000000000000000“ 2060451839"00000000700700007"97000 
ОДО0000000000 

000000Моаев је ООО00000000000С5М0000Дір.с5м 

00,202.127.0.0,202.127.4.255 

00,122.200.64.0,122.207.255.255 

О00Оподечсьм 0 441 П00сѕу000 

var fs = require('fs'); 

var csv = гедиїіге('с5м'); 


csv.parse(fs.readFileSync('ip.csv', 'utf8'), function (err, 
records) 1 
records.forEach(function (record) { 
importlP(record); 
}); 
}); 
ОПОПООШподе-сзу-рагве 00000 рог РООООООООООООО 
маг Redis = require('redis'); 
маг redis = new Redis(); 
//0 IP 000000 Redis 
/1/00000"Г'00', '202.127.0.0', '202.127.4.255']" 
function importIP (data) í 
var location = data[0]; 
маг тіпіР = convertlPtoNumber(data[1]); 
var тах!Р = convertlPtoNumber(data[2]); 
ИООБОБОБОБОВОВОВЯР" 
redis.zadd('ip', тіпір, '*' + location, тах[Р, location); 
} 
П0сопумегіРёоМитрег оО0001РО0000000000 
ПО ІР 00000 10 0000 
//convertlPtoNumber('127.0.0.1') => 2130706433 
function convertlPtoNumber(ip) 1 


var result = "; 
ip.split('.').forEach(function (item) 4 
item = —- item; 


item = item.toString(2); 
pad(item, 8); 


item 


result += item; 
}); 
return parselnt(result, 2); 
} 
раадрр000000000800 
/ПППППП'О'[П 
//pad('11', 3) => '011' 
function pad(num, n) í 
var len = num.length; 
while(len < n) í 
num = '0' + num; 
len++; 
} 
return пит; 
} 
ОДОО0000000000000000000000000 
маг readline = require('readline'); 
var rl = readline.createlnterface(1 
input: process.stdin, 
output: process.stdout 
}); 
rl.setPrompt('IP> '); 
rl.prompt(); 
rl.on('line', function (line) í 
ip = convertlPtoNumber*(line); 
redis.zrangebyscore(‘ip', ip, '+inf', 'LIMIT', '0', '1', 
function (err,result) í 


if (!Array.isArray(result) || result.length === 0) í 


ИО ТР 0000000000000 ІР ПО 
console.log('No data.'); 


) else í 
var location = result[0]; 
if (location[0] === '*') { 


ИО ТР 000000000 IP 000 
console.log('No data.'); 
) else í 
console.log(location); 
} 
} 
rl.prompt(); 
}); 
}); 
ОДО0000000 
$ node ip search.js 
ІР» 127.0.0.1 
Мо data. 
ІР» 122.202.23.34 
00 
ІР» 202.127.3.3 
ПП 
0000000000000000000000000000000000000000“*”00000 
ОО00000001РО000000 


ПО 
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pm install csv 


060 П 


О0005000000000000000004000000Аеаіѕ$=00000000000000 
ОДОД00000000000000000 Redis О00000000000000000000000 
ОДОООО000000000000000000000000000000000000000000000 
ОООД000000000000000000000000007 Red 6 Д00000"0 

000000000000000000—— "Веаї 00000700 


6.1 | 


4.2.2 (1000000000000000000 ІР 000 1 00000000010000 
$isKeyExists = EXISTS rate.limiting:$IP 
if $isKeyExists is 1 
$times =INCR rate.limiting:$IP 
if $times > 100 
print ОДОДОДОД000000000 
exit 
else 
MULTIr 
INCRrate.limiting:$IP 
EXPIRE$keyName, 60 
EXEC 


О0000000000000000000000%АТСНО000гаѓе.ітііпо:$ІРр 
ОООО0О0000000000000000000000000000000000000000000000 
ОД000000Веаї  ПО500000О0000000000000 

ООООВОПОООКей 5 ППОПОО"ВАТЕНМИИМ 6” 0000000000000 
ООО000000000000000000000000000000000000000000000000 
00000008 

if RATELIMITING rate.limiting:$IP, 60, 100 

print 0000000000000000 
else 
+ ПОООООООООО 

О000000000000000006еаіѕ$=000000000000000000000000 
О000000000000 Redis ОДООООО00000000000веаї 000000000 
000 


6.1.1 ІП 


Кеаіѕ2.600000000000000000чаПо000000Аеаіѕ000000иа 
Оробр000000веаї  рр000000006.100000000000-чар00000 
Кеа 5 ОПОПООПОООПОО 

01000000006. 1Q000000000000RedisOOSO0000000000000 
ОДОООО00000000000000000000 

U2000000Redis ОДООООО0000000000000000000000000000 
ОДООООО0000000000000000000000000000000000000000 

ОЗОДОДО00000000000000 Redis ОПООО000000000000000000 
ОДОООО0000000000000000000000 


6.1.2 [| II IILI 


ПППППППЦПППАКеа!5ПППШПШШИПШШППИПЦ а 0000 
local times = redis.call('incr', KEYS[1]) 
if times == 1 then 
-- КЕҮЅ[1]000000000000000 
redis.call('expire', KEYS[1], ARGV[1]) 
end 
if times > tonumber(ARGV[2]) then 
return 0 
end 
return 1 
ОДОДО000000000000000000000000000003ча 0000000000 
000000000000006.2000000.чароо000Аеаіѕро0000 
ООО0000000000000000000гаќеітііто.Ічарооо00000000 
$redis-cli --eval /path/to/ratelimiting.lua 
rate.limiting:127.0.0.1 , 10 3 
LE--evatBininrnredis-cHrbnnabmnmd bua ni 
/path/to/ratelimiting.lua []ratelimiting.lua 00000000000 
000 Lua П0000000*,"О0гаќе. limiting:127.0.0. 1000000000000 
000 КЕУЗ O00", "О00 100 300000000000ЦАКО VET ЈПАКОМГ2]Ц 
ООО000000000000000000000000001000030000000000000000 
ОООО00000019000000003000010000000 
00 0000007, О0000000000000000 
ПОКЕУЗДАВСУПСОДОДОб.ЗОДДОДООДОДОДОДООДООО а 000 


6.2 ша ||] 


Lua 1H QO000000000000Lua ПО00000“00" 00000000000000 
06-1000003ча Про"Об00"00000000000000000 


== = ^ 
~ 
7 
, 
/ 





- = 9 


06-1 Lua[ ПП 
ОПОООООООООО чай m a ad Ond Ond On and Cdi Phen er ii 
ООО0О000000000000000000000000 N 0000 N ооооооовоовом 
ОДООДО0000000000000000000000000000000000000000000000 
ООО00000000000000000300000000Арр Ѕёогеро500000000000 
ООООО00000000000000000МООО00000000000000000000МО000 
ООО0000МОООООО0000000000000000000000000000000000000 
ООО00000МОДООО00000000000"0000000000000000000007000 
ОДООДО000000000000000000000000000000000000000000000 
00000000000 App Store ВО00000000000000000000000000000 
00000—=00.чаоо000000000000000000000ииарооо000 
function feed(timeSinceLastFeed) 
local hungerValue = 0 
if timeSinceLastFeed > 3600 
hungerValue = ((timeSinceLastFeed - 3600) / 
timeSinceLastFeed) * 200 
return hungerValue 


end 

LLULLU JLual I IILI LILLILLILI U aug 
00000000бееаддОРееа ppp m pi i d m m ag dp nid d pa a D! nd 
ООООДО0000000000000000000000000000000000000000000000 
ООООД0000000000000000000000000000000000000000000000 
О0000000 

О0000іО50000000ичар00002011000000000000000000чад 
ПО00000000000ишабтовеЕбо000000000000100000000000000 
ПООБОСОВОВОО Е а 00000 

ПП Redis ООДООДОДОДОД0Д0О0000000000 Redis 00000000000 
ОПОООБОБОВОВОБОВБОВОВО Redis ОПОПОПОПОК ее [III 
О00000000000Аеаіѕ02.6000000чарооооо0оо00000Аеаіѕр 


6.2.1 ча 


Redis[|[]Lua 5.1 О000000000ича 00000000000000000шар 
ООО00000000000000Аеаіѕ000000000ичабоо000000000ша р 
[Roberto Іегиѕаіітѕсһу 12! ПОРгодгаттіпа in Lua 0000 

100000 

Lua ОО0000000000000000000000000 Redis 00000000000 
6-1000 

П6б-11шаЦПШШШП 


хина 


Z (nil) 


fü^K (boolean) 
ЖУР (number) 


FRP (string) 


dé (table) 


žr (function) 


HR в 
22 Н УМН, Bl nil. nil ERF, PAKE (А ЛУ ЗК ЕВЕ nx ERA 


Де nil 

Ai RAY LF true Al false PN {Н 

BOA a BAB XE EF FERRITE, 1, 0.2, 3.5е20 Ж 

РТР A АЕ, НБ Redis КН REE СИНИ I). RRB 
nf EH RS SRS] ERR, WHORES ERI]. Па", "o"n РАНУ» 
ГРАФІ ав ХОР, Шап. Хе SE 

«Ед Lua б рі НАВ A, BERT АН Ха е, FPR 
РА ACHE Lua АН. (first-class value), FJ GER aH. ЈЕДЕ 


ЕСІМІН Ж 


2000 

Lua О0000000000000000000000000000000000п1000 

a=1 -Uuulllla[li 

print(b) -ОД00000000000пії 

a=nil --00]0000а00000000090000000000000000000 
пи Да 000 

0 Redis 10000000000000000000000000000000000000000 
ОДіоса 00000000 

local c — -ОДД0000000с00000пії 


local а = 1 --П0000000900001 


local е, 


f --000000000000 


0000000000000000000 
local say_hi = function () 
print 'hi' 


end 


LLL III UO ILua[ III! 
0000000000 


апа 
end 


break do else elseif 
false for function if 


in local nil not or 
repeat return then true until while 
ОДООД00000000000000000000000 
local x = 10 
if true then 

local x = x + 1 

print(x) 

do 

local x = x + 1 
print(x) 

end 

print(x) 
end 
print(x) 
000008 
11 
12 
11 
10 
3000 
Счайообообдорово 
ОДО00--ОО0000000000000000000000000-000000000 
О0000--ПОО00100000 
"| 
ООБОБОВО 
]] 
4000 


LuaL]ILB D 

local а, b = 1, 2 - а [01060002 

local с, d = 1, 2, 3 -- «001090002030000 

local e, f = 1 -- еп ТОН 

LIED EDIDI EE ча 0000000000000 

local a = {1, 2, 3} 

locali=1 

i, ali] 2 і +1, 5 

Гиароороооооооооооовоо<0000 i, art] = 2, 5000000 ЇШЇП 


20а0045, 2, 3} 1810 


Сиабоаообободобободово 


0070 


50000 

Гай 5 00000 
0100000000000000000-+0-0%*0/3%00000-00000000000000 
ПОООО00000000000000000009000 

print('1' + 1) -- 2 

print('10' * 2) -- 20 


П2ПППППППЕчЧаПППППППП6-2ПП 
06-2 Lua[]HDDUE] 


J TE OH я ҢҢ 
== EE BEE LY XK AY НИН АЕТ ВАН 58 
~= Бізе ЈА RAR 
<, >, <=, >= Жер, XP. PPS upaqa 
ООДОДО000000000000000000000000000000000000000000 
00008 


print(1 == '1') -- false, ООДОДОД00000000000 


print({'a'} == Са)) --false, 000000000000000 
ОДООДО00000000000000000000000000006хмчФд 
print(1 == tonumber('1')) 
print('1' == tostring(1)) 
ОДєопипбег 00000000000000 
print(tonumber('F', 16)) - ОД00"Р0 16 0000 10 00000 15 
озоророрбїча0)00000006-3000 
06-3 ІмаПППППП 


iR E OF іл BB 
not TR i e РЕНО А НИБОНА НИК [8] false ЖІ true 
and a and Би Ка ж ERIS b, UNDRE а 
or a or b ЧИЖ а ЖІ ИЖ а, AMIE b 


ПООООООп ОЕа!верооаоооаоободободободоббабобообопо 
ПООООООПОК и БуОООПОООПООООООБОВОБОВОБОВООПО 


print(1 and 5) -- 5 
print(1 or 5) -- 1 
print(not O) -- false 
print('' or 1) - '' 


Lua О0000000000000000 false and foo()[ILua 0000 ғ#оо000 
ОООО00000000000Ро900000000000000000005аї15ебогоброО000 
П400000000000000000..00000000000000 


print('hello' .. ' ' .. 'world!') -- 'hello world!' 
ООО0О00000000000000000000 
print('The price is ' .. 25) -- 'The price is 25' 


ОЪПОБОБООБОБОБООПЕЦ ча 5.1 ООООООО00000000002800000 
Оббоббово 

рпп((# Пейо") -- 5 

00000000000006-4000 


06-4 ПО00000000000000 


not 4 - (—7t) 
* / % 


< > <= >= ~= mm 
апа 


or 


6[Jifl li 
Lua[|ifl 000000 
if 00000 then 
000 
elseif 00000 then 
000 
else 
000 
end 
ПО ОООООПЕЧарВО niig батероро00000000000 9000000000 
000000000000000 Redis [] EXISTS 00000 10 9 0000000000000 
000000 EXISTS 000000 1 ПП ОП exists 000000 truel 
if redis.call('exists', 'key') then 
exists = true 
else 
exists = false 
end 
00000 redis.call('exists', 'Кеу') ПП redis.call('exists', 'Кеу') 
== 10000 


Lua[javaScri pt000000000; Ооооо00О0о0ОбчароооогОечапоо 
LLL Lua 00000000000000000000000 
a=1 
b + 2 
if a then 
b=3 
else 
b=4 
end 
0000 
а = 16 = 2 На then b = З else b = 4 end 
ОДО000000000 
a = 
1b=2ifa 
then b = 3 else b 
= 4 end 
обебобобобобобобббоводо 
7010000 
Luaj while, repeat То ОООО 
whileQQU00000 
while ППППП do 
000 
end 
repeat 1010000 
repeat 
000 
until 00000 


Гогоообобобобобово 
for ПП=ПП, ПП, ПП до 
000 
епа 
ОДОДОб000000001200000007000010100000 
local sum = 0 
for i = 1, 100 do 
sum = sum + i 
end 
ПП богбОДОДОД0000000 100000000000 богобО00000000 
localQQU0U0000000 
forD pa 
for 00 1, 00 2, ..., OD N in DOO do 
000 
епа 
ОДОвеаїворородороро0РогооДБОДОДОДОДОДОО 
80000 
ПОцчароо000000000000000000000000000000000000000 
ООБОБОВО 
a= 4) --ПООаб0000000, 
a['field'] = 'value' --Пһеіа ОППуанче 
print(a.field) --]0000'маче'Да.ПеаПа['Ае!а' 00000 
people = { - 0000000 
name = "Во", 
age = 29 
} 
print(people.name) --000000'Воб' 


00 


ОДОСОД0000000000000000 

а = {} 

а[1] = 'Bob' 

а[2] = 'Jeff' 

ОД0000000 

а = ('Bob', Це! | 

print(a[1]) --ПППППП Bob" 
ПП шарооо 91 000002 000000000 
ОО0000000080г0000000000 


for index, value іп ipairs(a) do 


print(index) -- мдех  ППапип 
-- мачей ППаеППрги(«(уайне) 

end 

ПОБОБВО 

1 

Bob 

2 

Jeff 


іраігѕПіиарО000000000000000000000000000#ого0000000 


for i = 1, £a do 

print(i) 

print(a[i]) 
end 
О0000000000заррррдо0аор000 
Счар00000000раігѕ000000000000000 
people = { 


name = 'Bob', 
аде = 29 
} 
for index, value in pairs(people) do 
print(index) 
print(value) 
end 
000008 
пате 
Bob 
age 
29 
pairs[]ipairs ООД000000000000пй1000000000000100000000 
0000009000000 
9000 
0000000 
function (0000) 
000 
end 
ОДО00000000000000 
local square = function (пит) 
return num * num 
end 
оббобоббобабоборечароаообобоовобоббородоод 
local function square (пит) 
return пит * пит 
end 


ОДО00000000 
local square 
square = function (num) 
return num * num 
end 
000000000000 5дмагеррДооД0О000000000000000 
обобобобобобобобобоббобобод npn pnma u 
ОДООДО00000000000000000000000000000000000000000Ш...00 
ОДООр000000000000000 
local function square (...) 
local argv = {...} 
for i 1, #argv до 
argv[i] = argv[i] * argv[i] 
end 
return unpack(argv) 
end 
а, b, с = заџаге (1, 2, 3) 
print(a) 
print(b) 
print(c) 
000008 
1 
4 
9 
0005 адчагерор000000...000ОагаоморО00000000000000 
unpack 0000000000000000 argv 000 3 О00000геёигп 
ипрасК(агом) ППП return argv[1], argv[2], агом| ЗП 


HLuafjreturnGbreak 0000000000000 000000 000000000000 
0000000 етяПе!$е ит [0000000000000000000000000000000 
баобепаррооо 


6.2.2 ППП 


Lua 00000000000000000000000000 іраігѕ ОраїгБ 000000 
tonumber{] Еозелла ПО unpackUUUUUUUUUU“Base” ПП 
Кейі 000 ча 00006-50100 
06-5 Кея П-чай 


Е Ж Wi в 
Base Pe pt y — 3E l eR 28 
String EG T HT FFF E BEE ВОРА #4 
Table Je 0t Y HT Ae BRERS ER А 
Math Je t T МОРИН 
Debug Je pt Y FIT Ven er РК ЖИ 


СОООООООООООПОООБОООБОБОПОО0Ечайд 19: 0 

1[]Strinog[] 

String ООПООБОБОБООБОБОООБОБОВООБОВО string.len 
(string маг) ПОП пад var:len()[] 

02 000000000 

string.len(string) 

string. Теп()ПОПОООО# ПОПОВО 

> print(string.len('hello')) 

5 

> print(#'hello') 

5 

020000000 


string.lower(strina) 


string.upper(strine ) 

LEID) 

> print (string. lower ( 'HELLO ' ) ) 

hello 

> print (string.upper('hello') ) 

HELLO 

0300000000 

string.sub(strina start [,end  string.sub()Q0000000000 
[start ПППепа 00000000000200000000000--1000000000епа 
0000000000– 1000000000000 

000 

> print(string.sub('hello', 1)) 

hello 

> print(string.sub('hello', 2)) 

ello 

> print(string.sub('hello', 2, -2)) 

ell 

> print(string.sub('hello', -2)) 

lo 

2 Та еп 

TableQQU0000000000000000000 

0110000000000 

table.concat( table sep i 

table.concat()[JavaScri ркодіоіпООООО00000ПО000000000 
sep ПДООД0О00000000030)00000000000000000000002000000 
ОДОО0000000 


> print(table.concat((1, 2, 3))) 


123 


> print (table.concat({1, 2, 3), ',', 2)) 

2,3 

> print (table.concat({1, 2, 3}, ',', 2, 2)) 

2 

02000000000 

table.insert( table pos value 

000000022х5 дДОматиердрро00000000000»25 080000000 
1000000000000 


> а а {1, 2, 4) 

> table.insert(a, 3, 3) 

> table.insert(a, 5) 

> print(table.concat(a, ', ')) 

1,2,3,4,5 

U3000000000000 

table.remove( table pos 

ОДОДО00000000000000000000000000000225 BOBIBUIDBIDUIO 
ПОО00000000000 


> table.remove(a) 
> table.remove(a, 1) 
> print(table.concat(a, ', ')) 
3[]Math[] 
Мае ПДООДОО0О000000000000000000000000000000000006- 
60 
06-6 Ма ПППОПП 


BREN j š B 


math.abs (x) АНА НА 

math. sin (x) Ж = ff РАХ sin fÉ 

math. cos (x) R= ffi ER соз {Н 

math.tan (x) ЖЕ ff Fi % tan (8 

math.ceil (x) МЕ, ШП 1.2 MEE 2 

math. floor (x) ІНІ FERE, jn 1.8 HEF Zê 1 

math.max (x, ...) RASA НД X A 

math.min(x, ...) 3k 61 3 m sg NS RC 

math.pow(x, y) ЖИН xy КАН 

math.sqrt (x) 3k 483 x РРО R 
00000Маєврдор00000000 


math.random([m, |, n]]) 


math.randomseed (x) 


таїћ.гапаот()0000000000000000000000000000 

0000000000009, 1)0000 

0000" Oma p EL m JO TC 

00000 aan nan Em. a Ј0000 

гла! .гапдоп ОПОПООООООПОООв ееа ППОПОПОПООООООБОПО 
О000000000000000000таїћ.гапаотѕееа() 5650000000000 


> math.randomseed(1) 

> print(math.random(1, 100)) 
1 

> print (math.random(1, 100)) 
14 

> print(math.random(1, 100)) 
76 

> math.randomseed(1) 

> print(math.random(1, 100)) 
1 


> print (math.random(1, 100)) 
14 
> print (math.random(1, 100)) 
76 


6.2.3 ППП 


[000000008е915000<]зопП 19) ПствораскП E! ПППП5ОМП 
Ме55адеРаскППОПВе9!$01000000000000000000)5010 
сг59раскОПОДОДОДОДОДОДОДОООООО 

local people = { 

name = 'Bob', 
age = 29 

} 

- 00 cjson 00000000 

local json_people str = cjson.encode(people) 

--ПП cmsgpack 00000000 

local msgpack_people_str = cmsgpack.pack(people) 

- 00 cjson О0000000000000 

local json people obj = cjson.decode(people) 

print(json people obj.name) 

--ПП emsgpack ППОПОПОПОВОВОВ 

local msgpack people obj = cmsgpack.unpack(people) 

print(msgpack people obj.name) 


6.3 Redis[]|Lua 


Пр«еа  ООПОПОПООКея  ООООООПООКеят і чаро0000 
6.3.1 (ІІІ ПК ее 11 


О00000000Огеаїв са ПОддвеаїв trn n 
redis.call('set', 'foo', Баг) 
local value = redis.call('get', Тоо') -- value[][][]bar 
гед!5.са ПОПОПОПОКее ОООПОПОВО2 ПОПОКее ООПОПО5ОП 
ОДОгеаїз. са ДОДОДЗООДОДОДОДОДОВчаїб00000000000006-700 
О00000000000ишиарғаІѕерд 
06-7 Кеаіѕ$П000000чароо00000 


Redis 3& [E] (8 36 2 Lua REA 

кина FRAY 

ЕРЕ | FFF RAY 

£ (T3 ШШЕ! XU BAER) 

Хана KRN ( H 8 — ok Ez f fff lk ) 
ft АШ RAM (ИҢ — err ВИЙ ННЯ B 


x Redis{]000redis.pcall100000redis.caligooo0o0000000000 
redis.pcall0U0U0U00000redis.caliqdO000000000000 


6.3.2 0000000 


ОДООООО000000000000000000000000000000000000000000 
ОДгесого ООД00000000000000гевигодо0000п ИООО000000000 
Кеа 5 ОПОПОООПООООООБОВОБООК ей  ППОПОПООПОЕ- чай 000000 
Кеаіѕ00000000000000006-80000оаПғаіѕеПоо000000000000 

06-8 ІмаПППППЕеаі 00000000 


Lua ЗЕ Redis i& СИВ 25%) 


BF AY кина (Lua ff] 72570 ДЕЕ НАН) 
"ETE B RH "REB In] E 
ДЕНА (BAAS) iT FREE 
ӘЗ СА ok в ERASE ) RAS [n] Я 
AA (ИҢ — err FEC А | М) fii In] $2 
6.3.3 ПП 
1QEVAL ПП 


ОДОДОДОО0000000000000веаї ПОДЕМАЄОООДОДОДОДОГО 
КеаіѕД0000000000ЕУАЦЩОО0000ЕМАЦШОО0Ккеур0000 [kev ...] 
(ага ..1)0000хеу Qaro ПОООДОДООДОООООДОД0О0О0000000 
KEYS П ARGV 10000000000000000000000000$Е10000000000 
ОДО0000000000000 

return redis.call('SET', KEYS[1], ARGV[1]) 

ОО00геа 5-с И ПООООО 

redis> EVAL "return redis.call('SET', KEYS[1], ARGV[1])" 1 
foo bar 

OK 

redis> GET foo 

"bar" 

ООООООБООБООКеу 000000000002х2 00000000006-4000 
ПП 

ПП ЕМАТООООДОООООО0О0О0000000000 KEYSO АВ@С\УПОПОПО 
0000000000000000000000000000900 

2DEVALSHA ПД 

обобобобобоббббобобобОбОБОБОВОВО Redis 0000000000 
ОО0000000Аеаіѕ ПОП ЕМАЕ5НАрП000000000000 SHA1 000000 


ОО0000000 EVAL ПО000000000000000000 5НА1 ПОП 
Redis ППП EVAL 000000000 SHAT 0000000000000 
ЕМАТ5НАДООВеаї  ПООПООООО0О0О0Д000000000000000000000 
ОДОДО0О" NOSCRIPT Мо matching script. Please use EVAL.” 
ППППППЕУАІ5НАПППППИПОПГ 
ПАПППППППЫНАТПИППППЕУАБНАППООППП 
П200000000000* МОЅСАІРТ”ОО000ЕМАСТОО000000 
0000000000000000000000000 Redis rnnt in mtm mmu 
0000 node redis 00000 EVAL Q000node_redis 000000 
ЕМАЕЗНАПОПОПООВОВОВЕМАНОПО 


6.3.4 [NNN 


обобобобобоКео тъ пододододододобободбодо 
І1000000000000000 
Оббодообе аз оадобббабобобобббобооббовбобббобобобрдодо 
ООООООБОВОБООБОНСЕТА 00000 
Ргеаіѕ$Д000000006еаіѕ$Д0000000000000000000000000000 
ООООООБОВБОБООООБОНМОЕТАЦ ОМОПОПОВОБОО 
<?php 
class HMGetAll extends 
Predis\Command\ScriptedCommand 
{ 
//000000000000 KEYS ПП 
//false 1000000 
public function getKeysCount() 
{ 


return false; 

} 

//QO000U 

public function getScript() 

{ 

return 

<<<LUA 
local result = {} 
for і, м іп ipairs(KEYS) do 

result[i] = гед!5.са ('НСЕТАЦ“, м) 
end 
return result 
LUA; 

} 
} 
$client = new Predis\Client(); 
/ІПП hmgetall ПП 
$client->getProfile()->defineCommand(‘hmgetall’, 

‘'HMGetAll'); 
/ПП hmgetall ПП 
$value = $client->hmgetall('user:1', 'user:2', 'user:3'); 
2100000000000000000 
ОПОДООО00СРОРОКРОРООДОООДОООООДОДОДООО000000000000 
ООО000000000000000000 Redis 0000000000000 


WATCH 75е! 
$element =ZRANGE zset 0 0 
MULTI 


ZREM zset $element 
EXEC 
ООООО000000000000000000УУАТЕНОДОООДСОДОДОг5евр000 
000000 
redis-py ПППППП EVAL П EVALSHA О0000000000000 
register ѕсгіруОО0000000000000000000000000000000 
r — redis.StrictRedis() 
ша = """ 
local element = redis.call('ZRANGE', KEYS[1], 0, 0)[1] 
if element then 
redis.call('ZREM', KEYS[1], element) 
end 
return element 
ztop = r.register_script(lua) 
Я 0100000000 2ТОРО0000000 
print ztop(keys=['zset']) 
3000JSON 
3.200000000000000000$9мМ01000000000000000000000006 
ОДООДО000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000 
000000 
ИОООДО00000000000 
function Student(name) í 
this.name = name; 
this.courses = {}; 


} 


ГППИШШПЦПИШШПШШПП 
Student.prototype.addCourse = function(name, score) { 
this.courses[name] = score; 
} 
ОДОО0000000000000000 
/ПППП воБОДОД000000000 
маг bob = new 5кидепі( Вор'); 
bob.addCourse('Mathematics', 80); 
bob.addCourse('Literature', 95); 
#0000 Је# 00000000000 
var jeff = new Student('Jeff'); 
jeff.LaddCourse('Mathematics', 85); 
jeff.addCourse('Chemistry', 70); 
Ор«еа 5 ПОПОПО5О МОПОПОПКеа 5 0 
маг redis = require("redis"); 
маг client = redis.createClient(); 
/ППППП JSON 0000000000 
client.mset( 
'user:1', JSON.stringify(bob), 
'user:2', JSON.stringify(jeff) 
); 
ОО00000000000000ичароооооооооооо000000 
varlua= "\ 
local sum = 0 \ 
local users = redis.call('mget', unpack(KEYS)) 1 
for , user in ipairs(users) do N 
local courses = cjson.decode(user).courses \ 


for _, score in pairs(courses) do \ 
sum = sum + score N 
end \ 
end \ 
return sum \ 
П000поае гедіѕПема!00000000000000005НА10000000 
ЕУАГУНАОПООООПОБОБОЕМА 0000000000000 
client.eval(lua, 2, 'user:1', 'user:2', function (err, sum) í 
1000 330 
console.log(sum); 
}); 
ПП 00000000000 unpack Oo КЕҮЅП0000000000000000000 
ОДО000000000000000 


ООДОО00КЕУ5ПАВСУРОООООООДООДОООООД00000000 
6.4.1 КЕУЗПАВСМ 


000000000000000 KEYS 0 АКСУБООООООБОБОБООБОБОВБВО 
ОООО0О000000000000000 EVAL "return redis.call('get', 
KEYS[1])" 1 user:Bob 000 user:Bob 00000000000 EVAL 
"return redis.call('get', 'user:' .. ARGV[1])" 0 Bob ПООООООООО 
00000000 Redis 00000 KEYS ОДООООООДОДОД0О000000 


ороборорорбородородоророровеаї)00003.00000000 
0с1и$е0000000000000000000000000000000000000000000 
ООО000000000000000000000000000КЕҮЅ$П00000000000 
ООО000000000000000000000000000000000000000000000 
00000 ID ДОДО0Д0000000000000000000000000000000000000 
00008 
local sum = 0 
local users = redis.call(‘SMEMBERS', KEYS[1]) 
for , user id in ipairs(users) do 
local user age = redis.call('HGET', 'user:' .. user id, 
'age') 
sum = sum + user_age 
end 
return sum / #users 
000000000000000000 4 00000 KEYS ОООООДОДОДОО000000 
ОООО00000000000000000000000000000000001900000000100 
ПОООО0000000000000000000000000000000000000000000 


6.4.2 ПП! 


Redis ПОПОПО Lua ООООООО0О00000000000000000Веаї00 
[00000000Ве9!5000000000000000000000000000000000000000 

00000000000000000000000000000000000000000000000 
ОО0000000000000000000000000000000000000000000000А0ЕР 
ООДОО00000000 70000000000000000000000000000000000000 
ОДООД0000000000000000000 


обобобобобоббобобобобОкеатв ВО0000000000000000000 
0000 

UUUUUUUURedis 000 math.random П math.randomseed ПД 
ОДООДО0000000000000000000000000000000000000000000000 
ООООбО000000000000000000000000000000000000000 
math.randomseed(tonumber(ARGV[DO0000 ООООООООООО 
гла! .гапдоглообобобобоббббоброро 

ПОООО000000005МЕМВЕВ5ОООООООО0ДОДОНКЕУ5ОДООООО 
ОДОДОО0000 Redis ООДОДОДОДОД000000000 шар000ёаб!е.ѕогё 


ДбООО0000000000000 
function redis compare helper(a,b) 
if a == false then a = '' end 


if b == false then b = '' end 
return a « b 

end 

table.sort(result array, redis compare helper) 

DIEBOIBO pO pad dad d ad ag mg da d d pd dn nd Re d is 0100000000000 
ОПЮШча random ату ОбОДОДОДОДОДОДООООООДОДОД0000000 
[]]]j'Write commands not allowed after non deterministic 
commands.” [0 RedisUSPOPJSRANDMEMBER[] 
RANDOMKEYT[ITIME[] 


6.4.3 [| IILI 


[IEVALIJEVALSHAL[I[JRedisI ОО00040000000000000000000 


ООО0000000000 
1000000600 SCRIPT LOAD 


OOOUEVALQOORedisQQ0000SHA1Q00000000000000000000 
ПЕМАСЪНАООООООБОБОБООБОООБООВБООБООБООВБОБВО SCRIPT 
LOADI|I I II IL IUUSHA 100000000 

redis> SCRIPT LOAD "return 1" 


"e0elf9fabfc9d4800c877a703b823ac0578ff8db" 


20000000000000 SCRIPT EXISTS 
SCRIPT ЕХІЗ ТБООО00000200000005НА1 0000000000 


redis> 


SCRIPT EXISTS e0e1lf9fabfc934800c877a703b823ac0578ff8db abcdefghijklmnopqrst 
uvwxyzabcdefghijklmn 


1) (integer) 1 

2) (integer) 0 

300000000 SCRIPT FLUSH 

Redis ПППП SHAT 0000000000000000000000000000 
SCRIPT ЕЦЈ5НООООООООО 


redis> SCRIPT FLUSH 
OK 


4000000000000 SCRIPT KILL 
[000000000000000000 SCRIPT КІШ ПО000000000000 


6.4.4 [|| | IILI 


Кеа ППОПООООООБОПОПООК ее pnm bn pa ba pm a md 
ОООД000000000000000000000 Redis ПОППОПОПООООООППКеа!5 
DID Eua-time-Timit ООПООПОПОООООБОВО9З ООООБОООПООООООБОО 
RedisQQOU0000000000 000000000000 Dad d dd ! a dn On HOO 
"895У"00000000000геаї5-с ЇОДАОВОООДООООДОООДАОДОДОДООО 
00 


redis A> EVAL "while true do end" 0 

ОООД08О00000000 

redis B> GET foo 

ООООВООООВБОБООВОБОБООК ее в ДДобДбАродродрооорор000000 
ОДОДОООО0005000080007"ВУ5У"000 

(error) BUSY Redis is busy running а script. You can only 
call SCRIPT KILL or SHUTDOWN 

NOSAVE. 

(3.74s) 

ПП Redis ОО0ООО0О0О000000000000000005СКІРТ KILL р 
SHUTDOWN МО5АУЕП 

ОПОВОПО SCRIPT КІШПООО0000000000 

redis B> SCRIPT KILL 

OK 

обобоббобОБАбооооро 

(error) ЕКК Error running script (са! to 
f 694a5felddb97a4c6a1bf299d9537c7d3d0f84e7): 

Script killed by user with SCRIPT KILL... 

(28.77s) 

О000000000000000 Redis ООООООБООООО SETOLPUSH р 
DEL 00000 SCRIPT KILL 1000000000000000000000000000000 
ОООО00О00000000000000000000000000000000000000000000А 
0000 


redis А> 
EVAL "redis.call('SET', 'foo', 'bar') while true do end" 0 


о ОО00008000000000 


redis B> SCRIPT KILL 


(error) UNKILLABLE Sorry the script already executed 
write commands against the dataset. You can either wait the 
script termination or kill the server in an hard way using the 
SHUTDOWN NOSAVE command. 

000000 SHUTDOWN NOSAVE Dinard Кеаіѕ000 2 0000000 
LULUSHUTDOWNIII I JIRedis[][] SHUTDOWN МОб$АМЕППП 
ЗНУТООУУМПДОООООДОДОДОООООДОО00000О000000000000 7.1 
ПИПППППИПИППИППИП 

ПП Redis 1000000000000000000000000000000000000000 
ООО000000000000000000000000000000000000000000000000 
О000000000000000000000000006еаіѕ$0000000000000000000 
ШШШШИШШИШП 


ПП 

[1]. http://www.lua.org 

[2]. http://www.inf.puc-rio.br/—roberto 

[3]. Lua DOOO0000 20000000000 

[4]. ПО0950009000009000000000001 00000000 

[5]. http://www.lua.org/manual/5.1/manual.html#5 

[6]. http://www.kyne.com.au/~mark/software/lua-cjson.php 

[7]. cmsgpack Redis Salvatore ап рропрррроо 
https://github.com/antirez/lua-cmsgpack[] 


OZO ПО 


000 Кеаіѕ=00000000000000000000000000000000000 

Redis ЮДОДОВОДОООДОДОДОООДОООО0000000веаї 0100000 
ОДОДОО0000000000000000000 Redis В0000000000000000 

Д1р0кеаї  ОДОО000000000000000 

0200 Redis ООООДОООДОДОООО0ОД0000000000000000000 
ОБОБОБОБОБОВОВО 

000000 Redis ВООО0000000000000000000000000000000 
ОБОБОБОБОБОВОВО 

Кеа ОПОПОПОООБОВООКО ВОДООООДАОРОДОДОДОДОДООО"О 
П”О000000000000000000000000000000000000000000000000 
обобобобобббобобррро 


7.1 КОВ 


ВОВОДО0000000005пар5повїп9д000000000000вБеаї5000 
00000000000000000000000000000“0О”ОВеа!$000000000000 
00000 

e UU DD OO TL 

e ПППП SAVE[] ВСЪАМЕППП 

e [1 FLUSHALLODO 

e [| replication[j[] 


О000000000 


7.1.1 ПОДОДОО 0000 


Redis ПДОДОДОО0000000000000Веаї ОДОООО00000000000 
ОДООДОО00000000000000000000МОДОДОООС0МОДОООМОДОСОД 


О0000МО0000000000000Аеаіѕ$р0000000000000000030000 
save 900 1 


ѕаме 300 10 
ѕаме 60 10000 


О000000000000 save ППОО00000000000000000*0" 00000 
П000000ѕаме 900 1 00000 15 000900 П000000000000000000 
0000005ауе 300 10П00300000001000000000000 


7.1.2 ПІ 5АМЕП BGSAVE | | 


000 Redis ВООООООО000000000000000000000000000000 
О0Аеаіѕ000000000000000 

115АУЕПП 

О005АМЕППО0Аеаіѕ000000000000000000000000000000 
О000000000000000000000 Redis ПОПОООПООООООБОВОБОВОБО 
ППТ 

2ПВС5$А\МЕЦП 

О000000000000 BGSAVE ПО0ВС5АМЕ [II IILI III ILILI I! 
[000000000000000000000000000000 ВС5ЗАУЕПКей 5 III ОКПП 
ОДООД00000000000000000000 LASTSAVEIIIII IILI ILII I ILL 
ОДО0000009піхор0000 

redis> LASTSAVE 


(integer) 1423537869 
ПППППЦШППЦШИПП7.1.5ППЦШШИППЦПКеа!5ППППИПШИППШП 


7.1.3 [| ЕС ОБНА || 


000 FLUSHALL [|[|[IIRedis 1000000000000000000000000000 
0ОООооооооооооооооовоооооооокеа вороооооооовооооооо 
0000001000019 ОООПОПОООБОПООООООООВООБОПООР-Н5ЗНАНС 
обобобобобобобоббобобобобово 

О00000000000000Р005НАСПО000000 


7.1.4 ППО 


О0500000000Аеаіѕ ОДОДОООДОООООО00000000000000000980 
обобобобобобобобобобоббббобобобобобобобобобововово 
ПОКОВООООО 


7.1.5 ГІШ 


урвеаї  ПОООООООО0О000000000000000Веаї 000000000 
ПКей  ПОПОПОПОПОПдчгар гаьроДОДОООДОаї 96 епатероо 
обобобобобобобоббобобоборро 

ПІПКедіз 0богк ОООООООООООО0000000000000 

02 00000000000000000000000000000000000000000000 

03000000000000000000000000 RDB ВО000000000000 

ПП 000 fork ОДОД00000 Unix ВО00000000000сору-оп- 
умгіседДОД0РогкОДОООДОДОООДОООДООО0000000000000000000 


ШПЦПЦППЦППППППЦППЦПППППППППППППППИППИППИППИППППВАОРВЦППИПЦПШППП 
РогКОДОД0000 

ОДОДОД00000 fork О0000000000000000000000000000000 
О0000000000000002 оврбкеа 5 0000001.5 ев0000 feriri 
0000000003 ©8000000000000000 Linux 0000000000000000 
ОДДО00000000000000Д/ебс/зузсії. сопі ППОП 
vm.overcommit memory = 100000000000 sysctl 
vm.overcommit_memory=1 [O00000 

000000000000000000000000000000 fork 0000000000000 
000000000000000000000000000000000000000000 fork 0000 
ОДОД0000000000000000000000000000 

О0000000000квеаїв 0000000000008 280000000000000000 
0000000000000 RDB 100000000000000000000 RDB 00000 
Redis ПППОПОВОВ 000000000000гдбсопаргеззіоп ОД0000000 
СРОООДООДОООО0О0О0О000000000000000000000000 

Ведї  ОПОДОПЕО воббобобобобббобобобобобобобододобдо 
000000000000000000199090000000000001 GB 000000000000 
0002903000 

0082800000000008Ве91$000000000000000000000000000 
ОДОДОО00000000000000000000000000000000000000000000 
00000008Ве91$00]000000000000000000000000000000000000 
ООДОДОО0О000000000000000000А0Р00000000 


7.2 АОЕШ 


ОООКей 5 ПОПОПОПООООООООАОРОПООООООБОПОПОБОПОАОРЕ 
ОООКей  ПОПОООПООООБОБОПОБООООБОПООКеатв 10000000000 
ОО000000000000000000000000АОРО000 


7.2.1 ПАОЕ 


ПППППВеваіППППАОҒПаррепа only filet inimi 
аррепаопіуд0000 

аррепаопіу уе5 

ОДАОРОДООДООДОДОДКеаїЬОДОДООВеаї  ДПДО00000000 
АОРОДДАОвОДООДОООВОВОДДООООДОДООаЯОВОДОДОДООО 
аррепаоп!у.ао  ППаррепа !|епатейП ППП 

appendfilename appendonly.aof 


7.2.2 АОЕГТП 


АОРДДДОООО000000Веаї  ПОООПОДОООДОДАОРОДООДООО0000 
40000 

SET foo 1 

SET foo 2 

SET foo 3 

GET foo 

Redis[ ППЗПППППАОРППППППАОРПППИПОПОП 

*2 

$6 

SELECT 

$1 

0 


set 

$3 

foo 

$1 

3 

ПП АОРЦОООООО Redis 0000 Redis р000000000000Аеаіѕ00 
000009.2000000000000000000000000000000000Аеаіѕ$00000 
ООЗОДОО0000000000020000000000000000000000000000000 
ОббоббоабоббдАб F обобобббобобобббобобоббоббобобродро 
0000 Redis ООДООПАОРОДОДОДОООООООООВОДОДОДОДОДОДОДОО 


ДрвеаїбдООДОрО000000000000Веаї ОПООООАОРООДООДООО000000 
00008 

auto-aof-rewrite-percentage 100 

auto-aof-rewrite-min-size 64mb 

аиїо-аот1-геуугїїе-регсептадеЦППППЦППППППАОЕЦПЦППИППППИППШП 
ПОСАОҒООО00000000000000000000000000000000АОҒО00000 
ПЦачо-аоғгеуугіге-тіп-сіге ППІППП ПППАОҒЕППППППППАОЕП 
ОООДОрО000000000000000000000000Кеаї rir 
ООВСКЕ\М/ВГТЕАОРПОПОППАОРППП 

ПОСОАОҒОО00000000 

*2 

$6 

SELECT 

$1 

0 

13 

$3 

SET 

$3 

foo 

$1 

3 

ООООб00000000000000000000000000000 АОР0000000 
ВОВОрООО00000000000000 

ОПООКеетс  ДООООАОРОДОООООДОООООООО0000000000000 
КОВПШШШП 


7.2.3 Ш 


ОДОДОО000000000000А0Р00000000А0Р00000000000000 
ОООДОО00000000000000000000000000000000000003000000 
ОДОДОО000000000000000000000З9000000000000000000000 
ОДООО00000000А0к20рО00р0000000000000000Кецї ПППАОРОП 
00000000000000000000 Redis О000000 appendfsync 000000 
0000 

# appendfsync always 

appendfsync everysec 

# appendfsync no 

ОПО0ОКея Демегузесрдрр0000000000Оаїм гау0000000 
ОООООДО00000000000000п9о000000000000000000000000000 
ЗОб00000000000000000000000000ОемегузесПорДо000000000 
00000 

Redis ОООООО Абе 0 RDB[ IILI IILI IILI II! 
ППППВесі5ПЕедіз ПОДАОРОДООДОДОДОДАОРОДООООДОО0О0ОД0000О 


ISL п 


ОООО0000000000000 Redis ПОООО0000000000000000000 
урвеаї 000000 

0100000000 Redis ООООООООО00О00000000000000000000 
00000000000000000000000 

0200000000 Redis 100000000000000000000000000 

000000 Redis ОООООО00О00000000000000000000000000 

ПОООООООВОПО Redis ДОДООООО5епіїпетдод0Осіиввег 0000 
000 


8.1 П 


О00000006еаі$ПООО0000000000000000000000000000000 
ОДОООО000000000000000000000000000000000000000000000 
ОДООООД000000000000000000000000000000000000000000000 
О0000000 Redis ППООООгерИса ют ipaam m m ded m d bd |n Dat 
ОДООО000000000000 


8.1.1 [|| 


О00000000000000000000000таѕёегоо00000000. 
051амерПООо00000000000000000000000000000000000000000 


ОДООООО000000000000000000000000000000000000000000000 
00000008-1000 







МОРЕ В 


08-1 0000000000000000 

0 Redis ПООООООООООООООООООО00000000*$ахмео# ПППППП 
ОО000007" ПОО0000000000000 

ОДОООО0000000000000000000000000000000000000000 
Redis ОПОДОООО0ОО0000000000000000000000000000000000000 
Кеа 5  ОДОДО0000 

$ redis-server 

0000000637900000005амео#000000Аеаіѕ$П00000000000 
006380000 

$ redis-server --port 6380 --slaveof 127.0.0.1 6379 

000000000000000000000000000000000 redis-clirlA lu 
ШШШПП 

$ redis-cli -p 6379 


ОООгеаїз-сіїОВОДО000000 

$ redis-cli -р 6380 

ОДОДОДІМРОБДОДОООДАОСОВОДОВеріЇ cati en TETTE 

redis A> INFO replication 

role:master 

connected slaves:1 

Slave0:ip=127.0.0.1,port=6380,state=online,offset=1,la 
9-1 

master_repl_offset:1 

ОДОДОДОАООДОДОДОДОгоїе0Оплав5сеГоДОДОДОДОДОДОДОО 
о000000соппесіеа з!ауез ІШІП 

ОД00080000000000 

redis B> INFO replication 

role:slave 

master_host:127.0.0.1 

master_port:6379 

00000000О В р role 0 5і'амебобобОбОДОДОДОООП 
127.0.0 10000 63791 

ОООАОПО5Е ТООПОПОВОВО 

redis A> SET foo bar 

OK 

ОД00080000000000 

redis В» GET foo 

"bar" 

обебобободоббдобббобобоббоббоовободр 

redis B> SET Тоо hi 


(error) READONLY You can't write against a read only 
slave. 

О0000000000000000 slave-read-only П no 0000000000000 
ОООО000000000000000000000000000000000000000000000000 
ООО00000000000000000000000000000000000000 

О0000000000000000000000000000000 51амеої ОДО00000 
00008 

О000000000000000 бізуео ДО000000000 5 САМЕОРООООО 

redis> SLAVEOF 127.0.0.1 6379 

DEDE pana add Od Od OUS -АМЕОРОДОООООООО000000000 
ОО00000000000000000000 SLAVEOF NO ОМЕПОДОДОДОДОДОДО 
ШШШШИШШИШШШП 


8.1.2 П 


ПО Redis ОДОООООООО000000000000000000000000000000 
уррвеаї  ДД000000 

О000000000000000000 SYNC ООООО0000000 5УМСДОД0000 
ПООООООПОКОВООООЗОООВОООПООООБОООООБООВОБОПОООйКеан5 
ОДОООО000000000000000000000000000000000000000000000 
ОДООООД000000000000000000000000000000000000000000000 
0000000 

О0000000000000000Аеаіѕ 2.600000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
000000Ае91$ 2.80000000000000000000000000000000000000 


обобободобобобобобобобббообобобобОБОБобКеят пПопоро 
8.1.70000000000000000000000 
обобобобобббоббобобобобОбКеятопоротсробобобдодро 
000 telnet ПО0000000000000000000000000000000000000 
63 7900000000000000000 
$ telnet 127.0.0.1 6379 
Trying 127.0.0.1... 
Connected to localhost. 
Escape character is '7 ]'. 
ОПООООО000О00000ПРІМеДОДООДО00000000 
РІМІС 
+PONG 


0000000-РОМОеДОДОООООООДОДОДОДОДОДОДОДОДОДОДОДО 
ОДОО0000000АУТНОДДДОДОДОВеаї00000009.1000000000000 
ООВЕРЕСОМРООДООДООООДОДОООДОД000000 

ВЕРЕСОМЕ listening-port 6381 

+OK 


О000000000000000000005ҮМС 2! поооооооооооооооооо 
0ООоооооооооооооооотоопооовоовоовоововоооооооовово 
000 

5УМС 

$29 

REDIS0006?foobar?6_?" 

оеобобобободобобобоббабобобобббббббобобоббоково 
ПОООАРВ ПОООООБОООООООБООВОО dir Паоћіепатероо000000 
ОДОДООВОВДОДодДодДб000000000000000000000000000000000 
ООО00000000000000000000000000000000000000000 slave- 


5егие-{а!е-ЧакаППОпоПППОПИПИПИОИОНОППОПОИМРОЙ 
5| АМХЕОЕПДОДООО" SYNC with master in progress. ” 

ОООО0О000000000000000000000000000000000000000000 
ОО00000000000Кеаіѕ$00000009.20000000000000000000 SET 
foo ПіДОДЕе теєбДдо000 

*3 

$3 

set 

$3 

foo 

$2 

hi 

ОДОО0000000000000000000000000000 

ОДОООДО000000000000000000000000000000000000000000 
ОДОДОАФ8000000000000О5амердо0Овеаіз 2.8.18 П0000000000 
ПП 8.1.6 0000 

0000 Аеаіѕ$П0000000орїіітіѕііс геріїсаєіоПОДДОО00000000 
ОДОДОДОД0О00000000000000000000000кеадїв ОДОДОДОО000000 
ООООДО0000000000000000000000000000000000000000000000 
ООООД0000000000000000000000000000000000000000000000 
ОДООДО000000000000000000000000000000000000000000000 
ОДООДО0000000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 
ОДОДОДОД000000 Redis 1000000000000000000000000000000 
ООО000000000 

min-slaves-to-write З 

min-slaves-max-lag 10 


О000000тіп-51амеѕ-ёо-мгіќе00000З00ЗОО0000000000000 
ООО00000000000000000000 

redis> SET їоо bar 

(error) NOREPLICAS Not enough good slaves to write. 

min-slaves-max-lag О000000000000000000000000000000 
000000 REPLCONF АСКОП000000000000000000000000000000 
00000000000000000003000000000000000000000000000 9 0 
ОООО00О000000000000030000000000000000000000000000000 
О00020000000000000000000000000000000000000000000000 
00000000000000000000008.2000000 


8.1.3 ППП 


ОДООД000000000000000000000000000000000000000000 
8-2 ППППОПАПОВООООВОСОПОВОПИОООПОВОПЕОВОВОПИООПОООВА 
ОСОДООД00ВОЄ00 





08-2 000000000000 


8.1.4 [IILI III 


ОДООО0О000000000000000000000000000000000000000000 
000000Ае91$000000000000000000000000 SORT ООО00000000 
ОДООООО000000000000000000000000000000000000000000000 
[00000000000000000000000000Веа!$ 3.0 000000008.300000 
00 


8.1.5 [IILI 11] 


ОДООО0О000000000000000000000000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
ОДО00000 

ОДООО0О000000000000000000000000000000000000000000 
00000 

0100000000 SLAVEOF NO ОМЕДДОООООООООДООО00000 

О2000000000000000005 АМЕОРОДООООООООООО000000000 
00000000 

ПП ООО0000000000000000000000 Supervisor ПОПОПОПОПО 
ОДООООО000000000000000000000000000000000000000000000 
ОДООООО00000000000000000000000000000000000000000000 
ОДООООО00000000000000000000000000 

ОООО000000000000000000000000000000000Веаї5 000000 
ООО0000000000000000000000000000008.2000000000 


8.1.6 ШЦ 


8.1.2)000Ведїв ОПОООДОДОДООДООООВО ВООДОДОДОДОДОДОО 
00000 RDB ВО000000000000000000000000000000000000000 
ОДО0000000000 

О1000000008080000009009000000О5амедрооОДО0000000 
00008е91$00000А280000000000000000000000000000000000 
ООООД00000000000000000 

02000000000000000008980000000000000000000000000 
ООО0000000000000000 Redis ОО000000000000000000000000 
ОДоДобобобрДбррброрбобророрборборороророровеаї о 00000 
ООООД00000000000000 

0002.8.180д000кеаїб Дорбороро000000000веаїв m id 
ОДООДО0000000000000000000000000000000000000000000 

ОДОО0ДО00000000000000000000000000000000 

repl-diskless-sync yes 


8.1.7 IILI 


8.1.200000000000000000000000000000005УМС00000000 
ОДООООО000000000000000000000000000000000000000000000 
О000000000000000000000000000Кеаіѕ 2.80002.60000000000 
ОДОДОО000000000000000 

000000000300000 

01000000000000000О Огим 90000Веа!5 00000000000000 
ПІРО00000000000000000000100 

П2000000000000000000000000000000000000000000000 
ОраскіооПО000000000000000000000000 

ОЗОО00000000000000000000000000000000 


03000000000000008.2.2000000000000000000000000000 
0000000 SYNC 0000000000000000000000000 2.8 10000000 
5 УМСПОООООООООО РЪУМСППОО“РУМСПОПИООВ ID 000000000 
О0"0000000 Р5ҰМСОООООООО000000000000000000000 
ОЗ ПОДОО0ОО0О000000000019000000001900000000000000 
ОДООООО000000000000000000000000000000000000000000000 
00000 
02000000000000000000000000000000000000000000000 
00000000000000006 
О00000000000000000000000000000000Аеаіѕ 2.60000000 
О000000000000000000000000000000000000000000002.8 
О00000000000000000000000000005ҮМС 000000 2.8 0000000 
О000000000000000000 ЅҰМСПОО0000000000000000000000 
ООО0000000000000000000000000000000 1 мворорор000 
Пгер!-раск!од-512е ПОДООД000000000000000000000000000000 
ОДОООО000000000000000000000000000000000000000000000 
SET foo Баг ООООООО0000000000000000000000000000000000 
0000 
0000000000000000Огері-раскіод-СОДООООДОДООО000000 
ОО00000000000000000000000001000 


8.2 ПП 


8.10000АеаіѕО000000000000000000000К6еаіѕ000000000 
00000000000000000000000000000000000000000000000000 


ОДООООО000000000000000000000000000000000000000000000 
00000 

0008е91$ 2.8000000000000000000000000000 

ПО Redis 2.6 ППООО0000000000001.000000000000000000 
О0000000000000000000000000Аеаіѕ 2.800000 200000000 


8.2.1 1 ІП 


[000000000000008е91$0000000000000000000 
О10000000000000000000 
О20000000000000000000000000 
О000000000000000000000008-3000 


ВА 





08-3 ПОПОПОООПОВе9!$ ПОПОПОПОПООООООООООБОВОБО 
ПОООООПОК е В ПОПОПОООООПОООПООООООБОВОБОЦОО8-4П 
ОДООООО0000000000000000000000000000000 











ЕВЕ Ii 


т--- яв - == = сен... 


ие 
08-4 ОДОДООООД00000000000000 


8.2.2 ПД 


ОООООО00000000000000000000000000000000000000000 
8-200000000000000008.100000000030Аеаіѕ$00000000000000 
00000000000000063790000000000000638006381100006еаіѕ 
ОДООД0000000000000000000 

ОД000000 

redis 6379» INFO replication 

# Replication 

role:master 

connected_slaves:2 

slave0:ip=127.0.0.1,port=6380,state=online,offset=101 
25,lag=0 


Slavel:ip=127.0.0.1,port=6381,state=online,offset=101 
25,lag=1 

ООО000000000000000000000000000000009000 

redis 6380» INFO replication 

# Replication 

role:slave 

master_host:127.0.0.1 

master_port:6379 

redis 6381> INFO replication 

# Replication 

role:slave 

master_host:127.0.0.1 

master_port:6379 

LLLILILILILILLILILILILILILILILILILILILILI 0000, 

О0000000000000000000ѕепёпе!І.соп# 0000 

sentinel monitor mymaster 127.0.0.1 6379 1 

ППптутпавгег ПП ИИ ПИ 
000".- 70 з О0000000000000000000000000000000000000 
63 790 0001000000000000000000000005епіїпеторррр0000000 
00000000 

$ геа!5-зеп пе! /path/to/sentinel.conf 

ОДООО00000000000000000000000000000000000000000000 
ООО00000000000000000 


О00000000000000 
[71835] 19 Feb 22:32:28.730 # Sentinel runid is 
e3290844c1a404699479771846b716c7fc830e80 


[71835] 19 Feb 22:32:28.730 # +monitor master 
mymaster 127.0.0.1 6379 quorum 1 

[71835] 19 Feb 22:33:09.997 *+slave slave 
127.0.0.1:6380 127.0.0.1 6380 @ mymaster 

127.0.0.1 6379 

[71835] 19 Feb 22:33:30.068 *+slave slave 
127.0.0.1:6381 127.0.0.1 6381 @ mymaster 

127.0.0.1 6379 

00--5Їаме 0100000000000000000000000000000000000003 
Океан ПО ООО000000000000063790000Кеадїв on ii mii 
SHUTDOWN ДОДОбОД00000000000000 30 1000000000000 

[71835] 19 Feb 22:36:03.780 Я +sdown master 
mymaster 127.0.0.1 6379 

[71835] 19 Feb 22:36:03.780 # +odown master 
mymaster 127.0.0.1 6379 #quorum 1/1 

О0+ заомип ОПОПОБОБОБОБОВОВОВО+ одомип ПЦППШИШПШПШШП 
ООООДО000000000000000000000000000000000000000000000 
ОДО000000000000 

[/1835] 19 Feb 22:36:03.780 # +try-failover master 
mymaster 127.0.0.1 6379 

[71835] 19 Feb 22:36:05.913 # +failover-end master 
mymaster 127.0.0.1 6379 

[71835] 19 Feb 22:36:05.913 # +switch-master 
mymaster 127.0.0.1 6379 127.0.0.1 6380 

[71835] 19 Feb 22:36:05.914 *+slave slave 
127.0.0.1:6381 127.0.0.1 6381 @ mymaster 


127.0.0.1 6380 

[71835] 19 Feb 22:36:05.914 *+slave slave 
127.0.0.1:6379 127.0.0.1 6379 @ mymaster 

127.0.0.1 6380 

*try-failover( 0О0О0О0О0О000О failever-en dn a m 
ОООО0000000000000000000000000000000000000000000300 
O0+switch-master]Q00000637 90000063 800000638 09m igi 
ОДО0000000000-н51амепоборОООО000000000000006381П 
637900063 79000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 
ООО0000000000000000000000000000000000000637 90000000 
бО000000006380ро0р00000000000000063 7 9000000000000000 
63 80ПОО00000000000000063 790Д0000000000638000000000 
ПП 

ОО0000000000Аеаіѕ00000000063800638 1000000000000 
ПП 

redis 6380> INFO replication 

# Replication 

role:master 

connected_slaves:1 

slave0:ip=127.0.0.1,port=6381,state=online,offset=270 
651,lag=1 

redis 6381> INFO replication 

# Replication 

role:slave 

master_host:127.0.0.1 

master_port:6380 


00006389000000000000000000000638100000000000000 
ОДО000000000 

0000000637900000000000000000000000000000000000 
ПП 

[71835] 19 Feb 23:46:14.573 # -sdown slave 
127.0.0.1:6379 127.0.0.1 6379 @ mymaster 

127.0.0.1 6380 

[71835] 19 Feb 23:46:24.504 *+convert-to-slave slave 
127.0.0.1:6379 127.0.0.1 6379 

@ mymaster 127.0.0.1 6380 

-5аоми пДЛ0Ц76379000000000 $Ааомип ULU +convert-to- 
51аме000637900000000638о00000000000000Аеаіѕ 00000000 
6379 0000000000 

redis 6379> INFO replication 

# Replication 

role:slave 

master_host:127.0.0.1 

master_port:6380 

00638000000000000 

redis 6380» INFO replication 

# Replication 

role:master 

connected_slaves:2 

slave0:ip=127.0.0.1,port=6381,state=online,offset=292 
948,lag=1 

Slavel:ip=127.0.0.1,port=6379,state=online,offset=292 
948, lag=1 


0000000638000000000000000063 790000000 
8.2.3 00 
ОДООД0О000р00000000000000000000000000000 


sentinel monitor master-name ip redis-port quorum 

ЦО master-name ПДООО0О000000007.- "ОООО0000000000000 
ОООО000000000000000000000000000000000000000000000000 
ООО0000000000000 

ірО000000000000000геаіѕ-рог 000000 

ачогипДООООДОООО0О0О0О00000000000000000000 

оророро0000000веаї )р000000000О5еп'їпеї monitor 


00008 
sentinel monitor mymaster 127.0.0.1 6379 2 


sentinel monitor othermaster 192.168.1.3 6380 4 
000000000000000000 Redis О00000000000000000000000 
00000000000008.2.40000 
НО О III IILI] 
ОДО00000000000 
sentinel down-after-milliseconds mymaster 60000 
sentinel down-after-milliseconds othermaster 10000 
П00000000000тутаѕѓіегоёћегтаѕіе аомп-аќег- 
га іѕесоптаѕ0100060000110000[ 
ООООООООООООООООООООО0000000000000000АеаіѕП00000 
000000000000000 _ sentinel «пет ООООДОДОДОДОДОДОДОПО 
ООО0000000000000000 INFO 0000000000000000004.4.400000 
ООООДО000000000000000000000000000000000000000000 


0000000000000000000000030000 

01001 ООООДОООО0О000000ІМРОПОП 

0200 2 ОДОООО0000000000 sentinel :hello ОООООО00000 

03001, 0000000000000000000000ОРМОООО 

ОЗ0000000000000000000000000000003000000000000000 
ООО000000000000000 

ОПОДО01М РОБООДООООООДО0ОС0О0О000000019000000000000 
ОДОДОДОД000000000 Redis 1000000000000000000000000000 
INFO ОО0000000000000000000000000000000000 INFO 00000 
ООООДО000000000000000000000000000000000000000000000 
0000000000000000000000 10 ОБОООБООБОБОБОБОГМЕОВДОПОВО 
ООООДО0000000000000000000000000000000000000000000000 
ООО000000000 

000000000000 з5епбіпеї :пейо ВП0000000000000000000 
ОДО000000000000 

«000002», <00000>, «iub D>, «<0000000>, <0000000 
>, «90000002, «00000002, «utt 

ОООООО000000000000000000000000000000000000000000 
0000 _sentinel__:hello[ ПДОДООООДОДОДОООДОДОДОДОДОДОДОО 
ОООООО0000000000000000000000000000000000000000000000 
000000 РІМФООООДОООДООООО000О0000000000000000000000000 
ОДООДО0000000000000000000000000000000000000000000000 
ООООД000000000000000000000 

ОДОООДО000000000000000000000000000000000000000000 
О000000000000000РІМСПО000000000аомп-аҝег-тііѕесопаѕ 
UUUUUUdown-after-millisecondsUUUUTUUUUUUUUdown-after- 


пійзесопав ПОДДОДДОДОРІМОДОД |Jdown-after-milliseconds||[ |[ |[ 
100000000100000РІМСП00000 

IT 1 00000 РІМӘПП 

sentinel down-after-milliseconds mymaster 60000 

1/00 600 000000 PINGII[| 

sentinel down-after-milliseconds othermaster 600 

ПОДОдоу п-абнег-птійізесопавзбд Од ОО000000ПРІМОДООООДОЛОГ 
ОДОО00000000000О5ибіесіїмету аомипПОДОДПОДОДОДООО000000 
ООООДО000000000000000000000000000000000000000 
SENTINEL is-master-down-by-addr[(]D tuii BO 
О000000000000000000000000000објесііумеІу down! lla 
ОДООДО0000000000000000000000О9мчогипоророо0000000 

sentinel monitor mymaster 127.0.0.1 6379 2 

ОДОДО0000000 Sentinel ОООООООО0О0О00О000000000000000 
ООООД0000000000000000000000000 

ОООО00000000000000000000000000000000000000000000 
ООО00000000000000000000000000000000ка#%0000000000 

ПА ОО0О00000000000000000А00О000000000000000000000 
0000 

П20000000000000000000000А00000000 

ОЗОДб0АООД0000000Оамогипродрооб0ОД000000000000А000 
000000 

ОФ0000000000000000000000000000000000000000000000 
ОДООД000000000000000000000000 

UUUUUUUURaftUUUUUNttp://raftconsensus.github.io/ODUUUU 
ОДООДО000000000000000000000000000000000 

ОООО00000000000000000000000000000000000000000 


ОДООД0000000000000000000000000000000000000000 

О100000000000000000000000000000000$аме-ргіогіуро0 
OOO 

О200000000000000000000000000008.1.7 0000000000000 
ШШП 

0300000000000000001200000000 

О000000000000000000000 SLAVEOF NO ОМЕДДОДООООООО 
ОООООООООВОБОБОПОЗЕАМЕОЕРОООООБООБООООБООВОБОБОБООО 
0000000000000000000000000000000000000000000000000 
00000000 


8.2.4 ШЦ 


ОДОО0Д000000000000000000000000000000000000000000 
ОДОООО0000000000000000000000000000000000000000000000 
ООООД000000000000000000000000000000000000000000000 
0000 

01 ОО0О000000000000000000000000 

П2000000000000000000000000 

ОООООД000000000000000000000000000000000000000000 
ООООДО000000000000000000000000000 

0000 quorum 000 М/2 + 1000 М 000000000000000000000 
ОДО00000000000 

ОДОООД0000000000000000000000000000000000000000000 
000000000000000000000000000000000000 Redis 000000000 
О0000000000000 issuer] 
https://github.com/antirez/redis/issues/2257[ ПОП Кеа 5 0000 


ОДООООО000000000000000000000000000000000000000000000 
00000000000 


8.3 [I] 


0000000000 Redis ВОООО000000000000000000000000000 
О0000000000000000000000000000Аеаіѕ$П0000000000000000 
[000000000000000 Redis 0100000000000 

П Redis 0000000000 Redis 10000000000000000000000 
Redis [III III IILI III! 
[00200000000000400000000000000000000 27Ҹ0000000000 
ОДООООО000000000000000000000000000000000000000000000 
00000000000000000000000 

уррвеаї  ДОО00000000000000000рге5пагаїпта nn 
ПО0000000000000000000000000000000000000012800000000 
ОДОООО000000000000000000000000000000000000000000000 
ОДООООО00000000000000000000000000000000000000000000 
ОДООООО0000000000000000000 

ОО000000000000000000000000000000000000000Аеаіѕ 
з.ОПОО0000000000<Іічѕќег0000000—000*00” 00000000000 
ОДООООО0О0000000000000000000000000000000000000000000 
ОО00000000000000000000000000000М6ЕТОО0000000000000 
О00000000000000000000000000000000000000000000000 
ЅЕГЕСТООО000000000 

ОДООООО000000000000000000000000000000000000000000 
ОДООООД000000000000000000000000000000000000 


8.3.1 ШП 


ООО00000000000000січѕёег-епабіеадоооо0000000000000 
3000000000000 

ОООО000000000000000000000000З0ЗО000000000000000 6 
0 Redis ОДОООДОДОДОДО0000О cluster-enabled 00000000 

port 6380 

cluster-enabled yes 

ОПОрогіорДооб0000000000060000000306380063811 
638206383П638406385 000000000000000000000000000000О 
ОДОД00000000Опоаез  сопі ПООООООО0О00О00О000000000000000 
ОДОДОООО0Д0Д0О0000000000000000січ5єегесопйа-НТедюоОО 


00000 


cluster-config-file nodes.conf 


000000008-5000 


6380 > redis-server redis.con 
790 Feb 3:15 


redis-server 









6381 > деді 45-зегуег redis.con 
3 е 


nf on fou 
530 021 bbs 1c1c37f133 
г 385 > redis-server redis.conf 
ncreased max :M 23 Feb 13:15:08.968 * Increased max 
i as imum mber pen "files to 10032 (it was 







et 4 set to 2560) 
Feb 13:14:52.410 * No cluster co 1 23 b 13:15:08.969 * No cluster co 
n found, I'm 38326d2dbfd11c2656c nfig n 'm ругу е 5872535614ac 


B é f 
9239a9213f35295f4f3be e322f9b eif 7915ce90ece 


18 
е19а8724855с74а53 


08-5 0000000000 
ОДООООО0000000000000 


Мо cluster configuration found, I'm 
c21d9182eec935720f1622... 


Пре21а9182еесд3572011622.. ППОООООО ФОО РООООВОО 
ОООДО000000190000000000000 

ОПОПОПООКео 5 ПОПОПОБОБОБОВОВО INFO 0000000000000 
00 

redis> INFO cluster 

# Cluster 

cluster_enabled:1 

[cluster епав!еа 100000000000000000000000000000 
ОДО00000000000 

Кеаіѕ$П000000000000геаіѕ-гір.гө0000000000000000геаіѕ- 
ел .гобокчбубобобобобобоббобобобйичбубрббобобобобобово 
[][]redis-trib.rb ПОП gem р ге 5 ДОППП gem install redisQQ00 

UHredis-trib. ГБООООДОДОДОООО 

$ /path/to/redis-trib.rb create --replicas 1 127.0.0.1:6380 
127.0.0.1:6381 

127.0.0.1:6382 127.0.0.1:6383 127.0.0.1:6384 
127.0.0.1:6385 

ПП сгеаєерро00000000--геріїсаз 100000000000000000010 
ПО000000306/2000000003000000 

О0000геаіѕ-гію.го00000000 

>>> Creating cluster 

Connecting to node 127.0.0.1:6380: OK 

Connecting to node 127.0.0.1:6381: OK 

Connecting to node 127.0.0.1:6382: OK 

Connecting to node 127.0.0.1:6383: OK 

Connecting to node 127.0.0.1:6384: OK 

Connecting to node 127.0.0.1:6385: OK 


>>> Performing hash slots allocation on 6 nodes... 

Using 3 masters: 

127.0.0.1:6380 

127.0.0.1:6381 

127.0.0.1:6382 

Adding replica 127.0.0.1:6383 to 127.0.0.1:6380 

Adding replica 127.0.0.1:6384 to 127.0.0.1:6381 

Adding replica 127.0.0.1:6385 to 127.0.0.1:6382 

M: d4f906940d68714db787a60837f57fa496de5d12 
127.0.0.1:6380 slots:0-5460 (5461 slots) master 

M: b547d05c9d0e188993befec4ae5ccb430343fb4b 
127.0.0.1:6381 slots:5461-10922 (5462 slots) master 

M: 887fe91bf218f203194403807e0aee941e985286 
127.0.0.1:6382 slots:10923-16383 (5461 slots) master 

S: e0f6559be7a121498fae80d44bf18027619d9995 
127.0.0.1:6383 replicates 
d4f906940d68714db787a60837f57fa496de5d12 

S: a61dbf654c9d9a4d45efd425350ebf720a6660fc 
127.0.0.1:6384 replicates 
b547d05c9d0e188993befec4ae5ccb430343fb4b 

S: 551e5094789035affc489db267c8519c3a29f35d 
127.0.0.1:6385 replicates 
887fe91bf218f203194403807e0aee941e985286 


Can | set the above configuration? (type 'yes' to accept): 


ООДОО000000000000000000Оуе5 00П000000000000000000 


000000 


ППгесй-ігір ГБООООДОДОДООООООООООООРІМСОДОДОДОДОООО 
ООООО00000000000000000000 INFO ОО0000000001000000000 
ПООПО<ч$ег епабіеафбілд 

000000000000000 CLUSTER МЕЕТЦООООО CLUSTER MEET 
ip рог ПЦППППШПППИПЦППИППЇрПрог rd n m mp p d pd e 
00000000000000008.3.2000000 

[]L]redis-trib.rb[ Tan m p m p m Ond Od and dd and BO CPC] 
ООООО0000000000000000001РОООООООООО000000000000 

Using З masters: 

127.0.0.1:6380 

127.0.0.1:6381 

127.0.0.1:6382 

Adding replica 127.0.0.1:6383 to 127.0.0.1:6380 

Adding replica 127.0.0.1:6384 to 127.0.0.1:6381 

Adding replica 127.0.0.1:6385 to 127.0.0.1:6382 

0000000 638006381 р 6382 ППОООООООДОДО00000000 
6383063801000/ 06384163811010006385Пп63820П000П 

ОООО0000000000000000000000000000000000000000000 
8.3.ЗПООООООБОБОБООБОВОБОО CLUSTER КЕРШІСАТЕСОООООП 
1200000000000000000000 10 0000000000 

ОДОДОДОДО00000000 Redis ОДОДОДОДООООДОПОСЄТОЗТЕВ 
МОРЕЗ5ПООДО0000000000006380000 

redis 6380» CLUSTER NODES 

551e5094789035affc489db267c8519c3a29f35d 
127.0.0.1:6385 slave 

887fe91bf218f203194403807e0aee941e985286 0 
1424677377448 6 connected 


e0f6559be7a121498fae80d44bf18027619d9995 
127.0.0.1:6383 slave 
d4f906940d68714db787a60837f57fa496de5d12 0 
1424677381593 4 connected 
b547d05c9d0e188993befec4ae5ccb430343fb4b 
127.0.0.1:6381 master - 0 1424677379515 2 connected 
5461-10922 
d4f906940d68714db787a60837f57fa496de5d12 
127.0.0.1:6380 myself,master - 0 0 1 
connected 0-5460 
a61dbf654c9d9a4d45efd425350ebf720a6660fc 
127.0.0.1:6384 slave 
b547d05c9d0e188993befec4ae5ccb430343fb4b 0 
1424677378481 5 connected 
887fe91bf218f203194403807e0aee941e985286 
127.0.0.1:6382 master - 0 1424677380554 3 connected 
10923-16383 
ОООООО000000000000190000000000000000000000000000 
000 
redis-trib.roQUOQU0U00000U0000000000Redis 0000000000 
О000000000000000Огеаїв-єгі гБОООДОДОДОПО 


8.3.2 00000 


00000 redis-trib.rb 000 CLUSTER MEET ОДОООДОО00000000 
ПО000000000000000000000000000 CLUSTER МЕЕТООООООООО 
ОООО00000000000000А0000000000 


CLUSTER MEET ip port 
ірррогєПООООООООООООООООАООООООООООООООООО000000 


00800000080А00000000000080А0000008000605$1р00.'81_ПОП 
АПОООО00000000000000000000000000000000000 MEET 0000 
000000000000000000000 


8.3.3 ПП 


ООООООООБООООООБОВО CLUSTER КЕРЦСАТЕООООООООООО 
00000000000000000000000$191000000000000 

ОО000000000000001638400000000000000000000000000 
00000008. 3.10000000000 

М: d4f906940d68714db787a60837f57fa496de5d12 
127.0.0.1:6380 slots:0-5460 (5461 slots) master 

M: b547d05c9d0e188993befec4ae5ccb430343fb4b 
127.0.0.1:6381 slots:5461-10922 (5462 slots) master 

M: 887fe91bf218f203194403807e0aee941e985286 
127.0.0.1:6382 slots:10923-16383 (5461 slots) master 

00000000000000000000000063891000005460[054610000 
6381111П546111092215462111163821011П10923116383П 
546100000 redis-trib. roQQ00000000000000000 00000000 
КеаіѕД000000000000000000000000000 

ОООО0О000000000000000000000000000Аеаіѕ 10000000000 
ОООСКС 160000000000000 1 638 400000000000000000 1638400 
ООДОО0О0000000000000САС16000000000С0000000000000 

02 ОПОДО000Х00000Х00000020000010320000000000000000 
0403000000 


П2000000000000000000000000 
ПОООбейо. мога ороб'"пеїомогіа" ПД 
{иѕег102 ):Їа5і патеддр000"и5ег102"00ОДО0000000000000 
ООМСЕТООООДОД0000000000 Redis 1000000000000000000000 
ОДООДО000000000000000000000000000000000000 
{user102}:first.name [J{user102}:last.name ПОООООООООООО 
0000 МОЕТ {иѕег102 | Пг5 пате {user102}:last.name]Q000 
000000 
ОООО0О000000000000000000000000000000000000000000 
01 О00000000000000000000000 
П2000000000000000000000 
000000000 CLUSTER ADD SLOT S000 redis-trib.rb ПППП 
ПИПППППППППППППППППСЦУ5ТЕК ADDSLOTS(AOA000 
CLUSTER ADDSLOTS 51011 [slot2] ... [slotN] 
000 100 П 101 ПППППППППППППППППППППСЦУ5ТЕК 
ADDSLOTS 100 1010 Д0О000000000000000000 
(error) ЕВВ Slot 100 is already busy 
000000 CLUSTER SLOTSIII UL ILI LIL III 
redis 6380> CLUSTER SLOTS 
1) 1) (integer) 5461 
2) (integer) 10922 
3) 1) "127.0.0.1" 
2) (integer) 6381 
4) 1) "127.0.0.1" 
2) (integer) 6384 
2) 1) (integer) 0 
2) (integer) 5460 


3) 1) "127.0.0.1" 
2) (integer) 6380 
4) 1) "127.0.0.1" 
2) (integer) 6383 
3) 1) (integer) 10923 
2) (integer) 16383 
3) 1) "127.0.0.1" 
2) (integer) 6382 
4) 1) "127.0.0.1" 
2) (integer) 6385 
000000000000000003000000000000000000000000000000 
ОДООДО000000000000000000000000000000000 
00002000000000000000геаіѕ-ёгію.го00000000000000000 
О0000000геаіѕ-гір.гюр200006380000638100000000000геаіѕ- 
trib. rbQ00000 
ОрО0000000 
$ /path/to/redis-trib.rb reshard 127.0.0.1:6380 
ПОгеѕћага00геаіѕ-16.г60000000127.0.0.1:63800000000 
ОО000000000геаіѕ-6гію.г00000000000000геаіѕ-&гію.го000000 
ОДООД0000000000000000000 
How many slots do you want to move (from 1 to 16384)? 
О000000000000010000000геаіѕ-ёгію.го000000000000000 
What is the receiving node ID? 
0000 CLUSTER МОРЕ5ПДЛОСоЗ81ПДОІОДОДЛ 
b547d05c9d0e188993befec 4ae5ccb430343fb4bUUUUUUUUUU 
ОДО0000000000000 


Please enter all the source node IDs. 


Type 'all' to use all the nodes as source nodes for the 

hash slots. 

Type 'done' once you entered all the source nodes IDs. 
Source node #1:а! 
одорезвордорогоророробаоперороро000 
00000 уеѕ000000000000000000000 CLUSTER БІЮТӘППІПП 


ОДО000000000 
redis 6380» CLUSTER SLOTS 
1) 1) (іпіедег) 1 
2) (integer) 5460 
3) 1) "127.0.0.1" 
2) (integer) 6380 
4) 1) "127.0.0.1" 
2) (integer) 6383 
2) 1) (integer) 10923 
2) (integer) 16383 
3) 1) "127.0.0.1" 
2) (integer) 6382 
4) 1) "127.0.0.1" 
2) (integer) 6385 
3) 1) (integer) 0 
2) (integer) 0 
3) 1) "127.0.0.1" 
2) (integer) 6381 
4) 1) "127.0.0.1" 
2) (integer) 6384 
4) 1) (integer) 5461 


2) (integer) 10922 
3) 1) "127.0.0.1" 
2) (integer) 6381 
4) 1) "127.0.0.1" 
2) (integer) 6384 
ОООО0000000000000000000063 81000000000000 
П0геаіѕ-гіб.гюро000000000000000000геаіѕ-6гіб.г000000 
ооебоббобободр 
CLUSTER SETSLOT ППП NODE [100000 ID 
0000000000063800 
геаіѕ 6381> CLUSTER SETSLOT 0 NODE 
d4f906940d68714db787a60837f57fa496de5d12 
OK 
000000 CLUSTER SLOTS ООббобобоббобобобоббобовово 
000000000000000000000 CLUSTER ЅЕТЅСОТОПО00000000000 
ОООО000000000000000000000000000000000000007000708.3.4 
ОДОООО000000000000000000000000000000000000000000000 
0000 
ОДОО00000000000000 
CLUSTER GETKEYSINSLOT 00000000000 
ОООООООООМ СКАТЕООООООО0ООООО 
MIGRATE П0000000000000000000000 [COPY] [REPLACE] 
ООСОРҮрОО00000000000000000000000КЕРГАСЕПО000000 
ОО0000000000000000000000000000000000000000аюрсо0000 
006381000063800 
redis 6381> MIGRATE 127.0.0.1 6380 abc 0 15999 
REPLACE 


ООООО00000000000000000000000000000000000000000000 
ОО00000000000000000000000000000000000000000000 
CLUSTER ЅЕТЅЕОТЦОО0000000000000000000000000000000000 
ПООО00000000000000000000000000000000000* 00” 00000000 
ОО0000000000000000000000000000000000000000000000000 
ОДО000"00"000геаїз-єгіб ГБ ДДООДОООДОООДОВеаїЬОДОГОДООООО 
00000000000000000 

CLUSTER SETSLOT 000 MIGRATING 000000 ID 

CLUSTER SETSLOT 000 IMPORTING 000000 ID 

ППППППППППОППППАППИПВЦИППгесаі5-ігір.гӘПППППППППО 

0100800 CLUSTER SETSLOT 0 IMPORTING АП 

П2ППА ПП CLUSTER SETSLOT 0 MIGRATING ВП 

03000 CLUSTER GETKEYSINSLOT ОППОПППППППП 

П4ПООЗОПОБОПОБОМЮ КАТЕДООООПАОООВО 

05000 CLUSTER SETSLOT 0 NODE ВПППППП 

00000006 redis-trib.rb[]] 10 200000000000000000000000 
ПП“ПП”ПППИИШШППШППППППИППП A 0000 o 0000000000000000000 
ПО000000000000000 Азкороооооооооооо 80000 8-60000000 
ПО А5КОО0000000 ВПП А5КІМОСОДОДООООДООДОООДОДОООО000000 В 
0000 o 000000000000 ASKING 000000000000000 МОМЕОДОДО 
0008.3.400000008-7000000000000000045КОД0000000000000 
ООООДОДООр000000000000000070070000 









Еа 
XE. 
ІРО HEHEHE FR Жо! MOVE ВЖ, BEMAZIA 


08-6 АДОДО0000 





E3 
ХЕ 
1E ê AEG [o] 5 RE ASK ЇЙ Ж, BEF B 


08-7 В 0000000 


8.3.4 ППП 


8.3.30000000000000000000000000000000000000000 
ОДООО000000000000 

ОДООООО000000000000000000000000000000000000000000 
О0000000000000000000000000000000000000 MOVE 01000000 
ОДООООО000000000000000000000000000000000000000 

00000 Redis 00000 МОМЕДДОДОООООООО000О000000000000 
ОДОД000000000000000000000 Redis О0000000000000000000 
000 

О0000000000000#о00000638200000000006380000000 


ғ#оо00000000000000 
геаіѕ 6380> SET foo bar 


(error) MOVED 12182 127.0.0.1:6382 

ППППППМОУЕПППГПП12182Ц ЮОПППППП1127.0.0.1:6382П 
00000000000000000000000000000000000 63820000000 

redis 6382> SET foo bar 

OK 

КеаіѕП00000000000000000000000-<000000 

$ redis-cli -c -р 6380 

reds 6380> SET foo bar 

-> Redirected to slot [12182] located at 127.0.0.1:6382 

OK 

ОД000-Є00000000000000000000КВеаї ОООПОДО0О000000000 
ОДООДО000000000000000000 

ОООООДО000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000 

ОООО00000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 


ОООДО0000000000000000000000000000163840000000000000 
ОДОООО000000000000000000000000000 


8.3.5 [NNN 


О000000000000000000000 PING ОООООООО0000000000000 
ОО0000000000000000000010000000050000000000000000000 
OOPIN GOOO 

О00000000000000000000 PING О000000000000000 
ОРРАТЕДОДООДОООДООООДОООДООО00О00000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
000000000000000000 

01130000А0000800000000000000000000000000000000 
0000000 

П20000000000С00000000000080000000000000800000 
ОРАПОООООООДОООДОО00000000000В8000000000 

ОДООООО000000000000000000000000000000000000000000 
ОДООООО000000000000000000000000000000000000000000000 
ороборррбробоворорбобовородоророваноро00000 

01100000000000000000000А000000000000000000000 
00000000 

П200000000000000000000000А00000000 

ОЗО00АОООООО000000000000000000000000А0000000000 

ПАОООО000000000000000000000000000000000000000000 
ОДОООО0000000000000000000000000 

О00000000000000000000 SLAVEOF ОМ ОМЕПОООООООООО 
ОДООО0О0000000000000 


ООООООД00000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000Псіицзіег-геаціге- 
ТиІ-соуегадеГпоППППУе5ПП 

cluster-require-full-coverage по 


U ДО 
[1]. i "[][]Redis Redis 
[2]. Redis 2.8 PSYNC SYNC 8.1.7 


[3]. Gossip ППОО000000000000000000000000000000000000 





090 LIL 


ОООО00000000000000000000000 Redis ОООООО00000000 
Redis ООДОООООД0О00000000000000000000000000000000000 
0000000000000 

000000 Redis ВОО00000000000000000000000000Аеаіѕ=000 
00 


9.1 П 


Redis[][][]Salvatore сапйПрро по ОПКее -00 +! fono0Redis 
ПППППППППИПППВедів ПП 


9.1.1 [| III] 


Кеа 5 ППОПОПО“ Кей pn pao" Bam aan m an d bd |n On 
ППППП Redis ДОДОООООООД0ОС00000000000000000Веаї 000 
0000 

Кеа 5 ППОДОООД000000000000000000000001РОО00000 
Redis ООДОООООД0О0000000000000000000006паб000000000 


Прркеа 5 пооротароооо 
bind 127.0.0.1 


bind QO00000000-"*!_ П000000000000000000000000 


9.1.2 ППППП 


000000000000000Огеамігераз5)д0Кеаї  ДрО0000000 
requirepass TAFK(@~!ji*XALQ(sYh5xlwTn5D$s7JF 
00000000 Redis ООДОД000000 Redis О0000000000000000 
redis> СЕТ foo 

(error) ERR operation not permitted 
ППППППППАОТНПИППГПППГІ 

redis»? AUTH TAFK(@~!ji* XALQ(sYh5xlwTn5D$s7JF 

OK 

ОДО0000000000 

redis> СЕТ foo 

„ү! 

ООКео 5 ПОПОПОБОБОБОБООКея в ОПОПОПОПОПОООКеят 0000 


ОСОООООООООБОВОБОООКеет р О00100000000000000000000000 
00000000 


ПП ПП Redis Побоаообаоободободободоббодободо 


mastera uth) aan paa p p p OC DCOCIAU тнооооо 


9.1.3 ПІП 


Redis ПОООДОООД000000000 FLUSHALL ОДОООДОО0000000 


ОДОООО0000000000000000000 


rename-command FLUSHALL 


oyfekmjvmwxq5a9c8usofuo369x0it2k 


ОДООО000000000000000000000 
rename-command FLUSHALL "" 


00 О00000000000000000000000000000000000000 


9.2 ПП 


Redis[] LED RedisrirnnmRedis nn pap p aan an gb HI! 
00Ае91$00000000000А9ЕО000000000000000000000000000 
00000 Redis 100000000000000000000008е91$000000000000000 
ПКес 5 000000000000 

Кеа 5 ППОДОДОД0000000000000000Дипібеа request 
ргогосо  ПОДОДОДО000000 telnet ПООООООО0000000000000000 
ОДОО000000000000 


9.2.1 M 


ОО000000ќеіпеєО00Аеаіѕ000000000000000000000000000 
0000“ЕХІЅТ5 їоо"ДП"5ЕТ foo Баг”ППОП Redis О0000000000000 
О000000000000000000000006еіпеє 0000 

$ telnet 127.0.0.1 6379 

Trying 127.0.0.1... 

Connected to localhost. 

Escape character is '7 ]'. 

SET foo bar 

+OK 

GET foo 

$3 

bar 

LPUSH plist 1 2 3 

З 

LRANGE plist 0 -1 


#3 

$1 

3 

$1 

2 

$1 

1 

ERRORCOMMAND 

-ERR unknown command 'ERRORCOMMAND' 

ПП Redis 2.4 [0000000000000000000000000000000000006 
ПП 

С: SET foo 3 

C: bar 

S: +OK 

О0С:000000000005:0000000000000000000000000000000 
ОООООООООООООоООоооооооооооооооооооооооооооооооо00р 
ООО00000000700"О00000000000000000000000000000000000 
00000000000000009.2.200 00000000 

О00еіпеє00000500000000Аеаіѕ0500000000002.3.20000 
О50000000геаіѕ-сіі0О000000000000000геаіѕ-сіі00000000000 
Ведї  ОПОДОДОДОДОДОО 

100000 

О0000еггог геріубо-00000000000000000\%\п 000 

-ERR unknown command 'ERRORCOMMAND'\r\n 

200000 

UUUUUstatus геріуро+о00000000000000000\%\п 000 

+OK\r\n 


300000 

ОДОДОіпеедег replyE inni iin 000 

:З\г\п 

4000000 

ОДОДОДОВчік геріубо%000000000000000000\%\һ 000000000 
ОООСА\А\йО 

$3\r\nbar\r\n 

О00000000п11000009-20000000000 

S 00000000 

LLULLU Emulti-bulk reply Pf npn nd pm gm an gn] 
обебобабобобобооббодово 

*З\г\п$ 1\г\пЗ\г\п$ 1\г\п2\г\п$ Ала Ада 


9.2.2 ПП 


ОДОДО00О Redis 1.2 П00000000000000000000000000 SET 
foo Ба ПППОПОО00*З\Ап$ 3\nN\nSET\r\n$3\r\nfoo\n\n$3 
\\пбайииП ПІеіеППІП 

$ telnet 127.0.0.1 6379 

Trying 127.0.0.1... 

Connected to localhost. 

Escape character is '^]'. 

*3 

$3 

SET 

$3 


foo 


$3 

bar 

+OK 

ООДОД0000000000000000000000000000000000000000000 
ООДОД00000000000000 

Кеа Бг ПАОРООООДООДО00О0000000000000000000000000000 
О0Аеаіѕ$рО0000000000000000000000еіпе#кАеаіѕ$ро000000000 
ПО0000000 


9.3 ППП 


О00000000000000 Redis ВОО00000000 Redis О0000000000 
000000000 


9.3.1 redis-cli 


00000 redis-cli ОДОДОД000О Redis 1000000000000000000 
Кеаіѕ0П0000000000000Кеаіѕ00геаіѕ-сії0000000000 

геаіѕ-сіЇП0000000Аеаіѕ$00000000000001МРОрО000000000 
СОМЕІЄ000000КОВО005АМЕПОО000000000Аеаіѕ 000000000 

10000000 

О00000000000000Аеаіѕ00000000000000000000005Іоҹ 
logran slowlog-log-slower-thanp000000000 
000000001 000 000 000001000000010 Ос00000000000000000 
О0000000 slowlog-max-len ООДООО00000 

ПП SLOWLOG СЕТОДОДОООООООО000000 

redis> SLOWLOG СЕТ 


1) 1) (integer) 4 
2) (integer) 1356806413 
3) (integer) 58 
4) 1) "get" 
2) "foo" 
2) 1) (integer) 3 
2) (integer) 1356806408 
3) (integer) 34 
4) 1) "set" 
2) "foo" 
3) "bar" 
ОД0000004000000 
01000000120 
ог0000000Упіхобб 
ОЗОДОДО00000000000 
ОФ00000000 
ПП О0000000000000000000 slowlog-log-slower-thanQQ000 
ПОООООО000О00000000000000000000 
200000 
Redis[]JIMONITORIII IILI Redis[ рор0000Огеаї5-с Пп ОДОДДОП 
ПОПОгедт-с ПОПМОМПОВЦ 
redis> MONITOR 
OK 
ПП Redis ДОДОДОО0ЛО redis-cli О0000000000000 геаіѕ-сіір 
П SET foo баг 00000геаіѕ-сіі000000000 
1356806981.885237 [0 127.0.0.1:57339] "SET" "Ғоо" 
"bar 


МОМІТОВППППППВеаіз ППППППППППМОМІТОВПППППВесі<П 
ОО000000000МОМІТОАОО00000000000 


0000 Instagram. 13 000000000 MONITOR ПОП Redis 00000 
Пгеаіѕ-ѓаіпа[геаіѕ-ғаіпаа000МОМТОВД000000000000000000 
ПОСООООООО00Аеаіѕ$0000000000 

redis-faina 000000 https://github.com/Instagram/redis- 
Таїпаддд0000Огеаїв-їаї па руД 000000 

геаіѕ-ѓаіпа.руро000000000МОМТОВЦ00000000 

redis-cli MONITOR | head -n <0000000> | ./redis-faina.py 


9.3.2 phpRedisAdmin 


[]Redis 000000000геаїз-с їЇООДОООООПОДОДООООМу SQL 
ОПОрпрмуАадгот ООКеа 5 ПОПООРН РОООПОПОПООР йрКеа!5 
Admin[]phpRedisAdmin О0000000000000000000/00000000000 
обебоббоообово 

1100рһрВКеаіѕАатіп 

ПОрһрВАеаіѕАатіпо00000 

git clone 
https://github.com/ErikDubbelboer/phpRedisAdmin.git 

cd phpRedisAdmin 

phpRedisAdmin[|[|]PHP[]Redis[ 0ДОРГеаїзОДОДОДОДОДОДОЛОГ 
Predis[] 

git submodule init 

git submodule update 

200000000 


000 phpRedisAdmin 00000 Redis ППШШШШШШ 
phpRedisAdmin 0000127.0.0.1000637 9 00000000000000000 
Одіпстиае5ДДОДсопд.іпс. php ППП 

3000 phpRedisAdmin 


ПОРНРОМ/е ДОД Мої пх ОПОРАрКейт Ада пи ПДОДДО000000 
00000009-1000 


127.0.0.1 - phpRedisAdmin 


local server 


Redis version: 2.6.7 


Keys: 37 





Memory used: 1 MB 


Uptime: 3 hours 


Last save: 2 hours ago | 
f 
m 


"T 
i. Ф tag (3) phpRedisAdmin on GitHub 


Redis Documentation 








09-1 phpRedisAdmin ПП 
рһрКеаіѕАатіп0Веаіѕ000*:”0000000000000000000 
post:1[]post:2[ IILI Iposti 00 


ООД00000000000000000000000000000000000000009-20 
00 


eoo 127.0.0.1 - phpRedisAdmin я 


phpRedisAdmin post:28 7 x = 


| local server + | Type: hash 
osg TIL: does not expire 7 
= Add another key Encoding: ziplist 





[type here to filter ] е: 4 items 





|| Keys (3) 
Value 


з-вн и ж 
time 2012479218 2 ж 
author а Z ж 
content Фхавщн, дя. 7 Ж 


=} Add another value 











09-2 010000 
4000 
рпрКед5Адпи пп ПОПОПОПОПОКЕ У5# ООООООПОПООТУРЕООО 
О0000000000000000000000000000000000Аеаіѕ= 00000000000 
000000 KEYS *ПО0000000000000Аеаіѕ 1000000000000000000 
О000000000000000рһрАеаіѕАатіпо00 


9.3.3 Rdbtools 


Rdbtools 000Аеаіѕ ВО0О000000000000000050М№ 0000000 
Redis О000000000000Карќоо!ѕ ПОП Python 000000000 
https://github.com/sripathikrishnan/redis-rdb-tools[] 

1000 Rdbtools 


ППППППППКарїоо1!5[] 


git clone https://github.com/sripathikrishnan/redis-rdb- 
tools 

cd redis-rdb-tools 

sudo python setup.py install 

20000000 

ОДОДОДВОВОБООООО05АМЕДООДОВеаїООООООО 

30000000$9М00 

обобобобобоббббббборокабгоо 6 ПОПОПО5ЗО МОДОДОДО0 

rdb --command json /path/to/dump.rdb > 
output filename.json 

[L/path/to/dump.rdabUUUUUUUUUoutput_filename.jsonUUUUl 
000000 

4100000000008 

Кабёооі$000000000000000000000С5%0000000С5%00000 
Ехсе000000000000Аеаіѕ 0000000000 

гар -c memory /path/to/dump.rdb > output filename.csv 

ОООС5У00000000009-1000 

09-1 Rdbtools ПООС5УМОООООО 


+ в й В 

database FF AiG Ж ВЕНУ ОА РЕ як 5| 

type KE UEH TYPE ВОЗЕ) 

key Ж 

size in bytes BK (FT) 

encoding Amant, (AY OBJECTENCODING fi ЗА) 
num elements ВЕНУ TCR A 

len largest element BK TOR WARE 


ПО 
[1]. http://oldblog.antirez.com/post/redis-manifesto.html 
[2]. Redis 2.8 
https://github.com/antirez/redis/issues/274 


[3]. Instagram[]Facebook 





ОДА _Веа1$ [||| 


Redis 1000000000000000000000000000000000000000000 
000000000000000000000000000000000 


А.1 REDIS_CMD_WRITE 


ООВЕОІ5 СМО WRITE QUQU0U0U00000RedisQQ0000000000 
ООБОБОББОБОВЕО!5 СМО МУКП ЕООООПОБООЕ а np 
REDIS СМО ВАМРОМОДОДА.АОООО0000000000 
REDIS CMD WRITE 00000000000000“№гіёе commands not 
allowed after non deterministic commands." 

ПОВЕОІ5 СМО УУВІТЕНОДЛООООО 

SET 

SETNX 

SETEX 

PSETEX 

APPEND 

DEL 

SETBIT 

SETRANGE 

INCR 

DECR 


RPUSH 

LPUSH 
RPUSHX 
LPUSHX 
LINSERT 

RPOP 

LPOP 

BRPOP 
BRPOPLPUSH 
BLPOP 

LSET 

LTRIM 

LREM 
RPOPLPUSH 
SADD 

SREM 

SMOVE 

SPOP 
SINTERSTORE 
SUNIONSTORE 
SDIFFSTORE 
ZADD 
ZINCRBY 
ZREM 
ZREMRANGEBYSCORE 
ZREMRANGEBYRANK 
ZUNIONSTORE 


ZINTERSTORE 
HSET 
HSETNX 
HMSET 
HINCRBY 
HINCRBYFLOAT 
HDEL 

INCRBY 
DECRBY 
INCRBYFLOAT 
GETSET 
MSET 
MSETNX 
MOVE 
RENAME 
RENAMENX 
EXPIRE 
EXPIREAT 
PEXPIRE 
PEXPIREAT 
FLUSHDB 
FLUSHALL 
SORT 
PERSIST 
RESTORE 
MIGRATE 
BITOP 


A.2 REDIS CMD DENYOOM 


ПП REDIS_CMD_DENYOOM ПОПОПОПООО Redis ОДОДО0000 
00000000000 REDIS_CMD_WRITE ОПООООДОООД000ОЕ 0000 
REDIS_ СМО WRITE 0100000000000000000000000 
REDIS СМО рЕМУООМЦЦЦ 

ПООО0000000000000тахтетогу О00000000 
maxmemory-policy ВОО00000000000000Кеаіѕ ПОПОПОП 
REDIS СМО рЕМУООМЦООООО 

ПО 00 REDIS_CMD_DENYOOM ОООООООООООДООО0000000 
0000000000000000$ЕТ ВО0000000000000000000000000000 
О0000000000000006еаіѕП0000000 REDIS_CMD_DENYOOM ПП 
00000000000000000000000000 

ПОВЕОІ5 СМО ОЕМУООМОООООООД 

SET 

SETNX 

SETEX 

PSETEX 

APPEND 

SETBIT 

SETRANGE 

INCR 

DECR 

RPUSH 

LPUSH 

RPUSHX 

LPUSHX 


LINSERT 
BRPOPLPUSH 
LSET 
RPOPLPUSH 
SADD 
SINTERSTORE 
SUNIONSTORE 
SDIFFSTORE 
ZADD 
ZINCRBY 
ZUNIONSTORE 
ZINTERSTORE 
HSET 

HSETNX 
HMSET 
HINCRBY 
HINCRBYFLOAT 
INCRBY 
DECRBY 
INCRBYFLOAT 
GETSET 

MSET 

MSETNX 

SORT 
RESTORE 
BITOP 


А.З REDIS CMD NOSCRIPT 


ПОКЕО!5 СМО МО5СВІРТОДОДОООДВеаїьЬОООООО 

ПП EVAL П EVALSHA ПОПОО0000000000000000000000000 
ОПОВОВО 

ПОВЕОІ5 СМО МОЗСВІРТОООООООД 

BRPOP 

BRPOPLPUSH 

BLPOP 

SPOP 

AUTH 

SAVE 

MULTI 

EXEC 

DISCARD 

SYNC 

REPLCONF 

MONITOR 

SLAVEOF 

DEBUG 

SUBSCRIBE 

UNSUBSCRIBE 

PSUBSCRIBE 

PUNSUBSCRIBE 

WATCH 

UNWATCH 

EVAL 


EVALSHA 
SCRIPT 


A.4 REDIS_CMD_RANDOM 


0000000000 REDIS_CMD_RANDOM ПО000000000000 
REDIS СМО МАІТЕ000000006.4.200000 

ПОВЕОІ5 CMD ВАМООМООДОО 

SPOP 

SRANDMEMBER 

RANDOMKEY 

TIME 


A.5 
REDIS CMD SORT FOR SCRIPT 


ПОВЕРІ5 СМО SORT. FOR 5СВІРТОДОПОДОО0ООО0О06.4.2 
оророррорродорвеа о рр000000 

[IJREDIS СМО SORT FOR 5СВІРТООООООО0 

SINTER 

SUNION 

SDIFF 

SMEMBERS 

HKEYS 

HVALS 


KEYS 


A.6 REDIS CMD LOADING 


овеаїб р ОД00000000000000000Веаїв 00000 
REDIS CMD_LOADINGQQOUOUU 

ППҺЕрІ5 СМО ШОАРІМСО0000000 

INFO 

SUBSCRIBE 

UNSUBSCRIBE 

PSUBSCRIBE 

PUNSUBSCRIBE 

PUBLISH 

2.6.ЛІПППППАОТНГ2.6.12ПППППОЕГЕСТП 


ПОВ ПОПОВО 


ПОО0ООКей в ПОПОПОООООБОПОПООВ- 16] 
ПВ-1 Redis 0000000000000 


з ща 


daemonize 


pidfile 


port 
databases 


save 


rdbcompression 
rdbchecksum 

dbfilename 

dir 

slaveof 

masterauth 
slave-serve-stale-data 
slave-read-only 


requirepass 


я GA {Н 
no 
/var/run/redis 
/pid 
6379 
16 
save 9001 
save 30010 


save 60 10000 


45 FA CONFIG 
SET i2 
ARI UA 
Au, 


жирі, 
жад 
ШИЛ 


AY LA 
Шъ 
Ay LA 
AS ay UL 
жара 
ША 
ШУ 
ШЕЛ 
Ay LY 


714 
7.1.1 
8.1.1 
9.1.2 
8.1.2 
8.1.1 
9.1.2 


00 


(Е FH CONFIG 


9 95 + му f ЗЕТЕ = 
rename-command X Жар 9.1.3 
maxmemory X ШЕ! 4.2.4 
maxmemory-policy volatile-lru ATL 4.2.4 
maxmemory-samples 3 nf EJ 4.2.4 
appendonly no nf EJ 7.1.2 
appendfsync everysec nf EA 1.12 
auto-aof-rewrite-percentage 100 wy UJ 7.1.2 
auto-aof-rewrite-min-size 64mb [ПШ 1.2. 
lua-time-limit 5000 ut, 6.4.4 
slowlog-log-slower-than 10000 п] РА 9.3.1 
slowlog-max-len 128 Ay UJ 931 
hash-max-ziplist-entries 512 [ПШ] 4.6.2 
hash-max-ziplist-value 64 прод 4.6.2 
list-max-ziplist-entries 512 nf EJ 4.6.2 
list-max-ziplist-value 64 HY LA 4.6.2 
set-max-intset-entries 512 ny) 4.6.2 
zset-max-ziplist-entries 128 Ay UJ 4.6.2 


zset-max-ziplist-value 64 nf EJ 4.6.2 


Ше CRC16[ П 


Redis ППППСВС16 ППОПОПОПОВОСОВ slot ПООПОПВАМУ! СП 
ОО0000000000Січѕёеоо00000000000000000Аеаіѕ 000 
[]http://redis.io[][] 

/* 

* Copyright 2001-2010 Georges Menie (www.menie.org) 

* Copyright 2010 Salvatore Sanfilippo (adapted to Redis 
coding style) 

* All rights reserved. 

* Redistribution and use in source and binary forms, 
with or without 

* modification, are permitted provided that the following 
conditions are met: 

* 

* ж Redistributions of source code must retain the 
above copyright 

б notice, this list of conditions апа the following 
disclaimer. 

* * Redistributions in binary form must reproduce the 
above copyright 

+ notice, this list of conditions and the following 
disclaimer in the 


* documentation and/or other materials provided 
with the distribution. 

* ж Neither the name of the University of California, 
Berkeley nor the 

* names of its contributors may be used to endorse 
or promote products 

* derived from this software without specific prior 
written permission. 

* 

* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND 
CONTRIBUTORS ``AS І5" AND ANY 

* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT 
NOT LIMITED TO, THE IMPLIED 

* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 
A PARTICULAR PURPOSE ARE 

* DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND 
CONTRIBUTORS BE LIABLE FOR ANY 

* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, 
OR CONSEQUENTIAL DAMAGES 

* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
SUBSTITUTE GOODS OR SERVICES; 

* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
INTERRUPTION) HOWEVER CAUSED AND 

* ON ANY THEORY OF LIABILITY, WHETHER IN 
CONTRACT, STRICT LIABILITY, OR TORT 

* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 
ANY WAY OUT OF THE USE OF THIS 


* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 
SUCH DAMAGE. 

s 

/* CRC16 implementation according to CCITT standards. 

ж 

ж Note by @antirez: this is actually the XMODEM СЕС 16 
algorithm, using the 


* following parameters: 
* 


* Name : "XMODEM", also known as 
"2МОРЕМ", "CRC-16/ACORN" 

* Width : 16 bit 

* Poly : 1021 (That is actually x^16 + x^12 + 
x^5 + 1) 

* |nitialization : 0000 


* Reflect Input byte : False 

* Reflect Output CRC : False 

* Xor constant to output CRC : 0000 

ж Output for "123456789" : 31C3 

*/ 

static const uint16 t crc16tab[256]= í 

0x0000,0x1021,0x2042,0x3063,0x4084,0x50a5,0x60c6, 
0x70e7, 

0x8108,0x9129,0xa14a,0xb16b,0xc18c,0xd1ad,O0xelce, 
Oxflef, 

0x1231,0x0210,0x3273,0x2252,0x52b5,0x4294,0x72f7, 
0x62d6, 


0x9339,0x8318,0xb37b,0xa35a,0xd3bd,0xc39c,0xf3ff,0 
xe3de, 
0x2462,0x3443,0x0420,0x1401,0x64e6,0x74c7,0x44a4, 
0х5485, 
0xa56a,0xb54b,0x8528,0x9509,0xe5ee,0xf5cf,0xc5ac,0 
xd58d, 
0x3653,0x2672,0x1611,0x0630,0x76d7,0x66f6,0x5695, 
0x46b4, 
0xb75b,0xa77a,0x9719,0x8738,0xf7df,0xe7fe,0xd79d,0 
xc7bc, 
0x48c4,0x58e5,0x6886,0x78a7,0x0840,0x1861,0x2802, 
0x3823, 
Oxc9cc,0xd9ed,0xe98e, Oxf9af,0x8948,0x9969,0xa90a,0 
xb92b, 
Ox5af5,0x4ad4,0x7ab7,0x6a96,0x1a71,0x0a50,0x3a33, 
Ох2а12, 
Oxdbfd,Oxcbdc,Oxfbbf,Oxeb9e,0x9b79,0x8b58,0xbb3b,0 
xabla, 
Охбсаб,0х7с87,0х4се4,0х5сс5,0х2с22,0х3с03,0х0с60, 
Ox1c41, 
Oxedae,Oxfd8f,Oxcdec,Oxddcd,Oxad2a,0xbdOb,0x8d68,0 
x9d49, 
0x7e97,0x6eb6,0x5ed5,0x4ef4,0x3e13,0x2e32,0x1e51, 
0х0е70, 
Oxff9f,Oxefbe,Oxdfdd,Oxcffc,Oxbflb,0xaf3a,0x9f59,0x8f7 
8, 


0x9188,0x81a9,0xb1ca,0xaleb,0xd10c,0xc12d,0xfl4e, 
Oxelof, 
0x1080,0x00a1,0x30c2,0x20e3,0x5004,0x4025,0x7046, 
0х6067, 
0x83b9,0x9398,0xa3fb,0xb3da,0xc33d,0xd31c,0xe37f,0 
xf35e, 
0x02b1,0x1290,0x22f3,0x32d2,0x4235,0x5214,0x6277, 
0х7256, 
Oxb5ea,0xa5cb,0x95a8,0x8589,0xf56e,0xe54f,0xd52c,0 
xc50d, 
0x34e2,0x24c3,0x14a0,0x0481,0x7466,0x6447,0x5424, 
0х4405, 
0xa7db,0xb7fa,0x8799,0x97b8,0xe75f,0xf77e,0xc71d,0 
xd73c, 
0x26d3,0x36f2,0x0691,0x16b0,0x6657,0x7676,0x4615, 
0x5634, 
0xd94c,0xc96d,0xf90e,0xe92f,0x99c8,0x89e9,0xb98a,0 
ха9ар, 
0x5844,0x4865,0x7806,0x6827,0x18c0,0x08e1,0x3882, 
Ох28аз, 
Oxcb7d,0xdb5c,Oxeb3f,Oxfble,0x8bf9,0x9bd8,0xabbb,O 
xbb9a, 
0x4a75,0x5a54,0x6a37,0x7a16,0x0af1,0x1ad0,0x2ab3, 
0x3a92, 
Oxfd2e,0xedOf,Oxdd6c,Oxcd4d,Oxbdaa,Oxad8b,0x9de8,0 
x8dc9, 


0x7c26,0x6c07,0x5c64,0x4c45,0x3ca2,0x2c83,0x1ce0, 
OxOccl, 
Oxefl1f,Oxff3e,Oxcf5d,Oxdf7c,Oxaf9b,Oxbfba,Ox8fd9,0x9ff 
8, 
0x6e17,0x7e36,0x4e55,0x5e74,0x2e93,0x3eb2,0x0ed 
1,0xlef0O 
}; 
uint16_t crc16(const char *buf, int len) í 
int counter; 
uint16_t crc = 0; 
for (counter = 0; counter < len; counter++) 
crc = (crc<<8) ^ crcl6tab[((crc>>8) ^ 
*buf++)&0x00FF]; 
return crc; 


